对于调用DataAdapter.Update 方法时发生的错误解决办法
2013-08-07 00:04
351 查看
今天,想着用dataset的方法来对数据库表和datagridview的表格数据进行更新,删除操作,却没有想到会出现异常,一直报错,后来,在杨大哥的帮助下,解决了这个问题。
原来,是这样的!
如果 DataTable 映射到单个数据库表或从单个数据库表生成,则可以利用 CommandBuilder 对象自动生成 DataAdapter 的 DeleteCommand、InsertCommand 和 UpdateCommand。为了自动生成命令,必须设置 SelectCommand 属性,这是最低的要求。SelectCommand 所检索的表架构确定自动生成的 INSERT、UPDATE 和 DELETE 语句的语法。如果在自动生成插入、更新或删除命令后修改
SelectCommand 的 CommandText,则可能会发生异常。如果已修改的 SelectCommand.CommandText 所包含的架构信息与自动生成插入、更新或删除命令时所使用的 SelectCommand.CommandText 不一致,则以后对 DataAdapter.Update 方法的调用可能会试图访问 SelectCommand 引用的当前表中已不存在的列,并且会引发异常。可以通过调用 CommandBuilder 的 RefreshSchema 方法来刷新 CommandBuilder
用来自动生成命令的架构信息!
最后,我在代码里面加入了,
SqlCommandBuilder ss = new SqlCommandBuilder(da);
ss.RefreshSchema();/
/成功的解决了删除的时候所引发的异常:
看来,要学习的东西还有很多啊!这么简单的问题居然困扰了我半天时间!!!加油!
Fighting!!
原来,是这样的!
如果 DataTable 映射到单个数据库表或从单个数据库表生成,则可以利用 CommandBuilder 对象自动生成 DataAdapter 的 DeleteCommand、InsertCommand 和 UpdateCommand。为了自动生成命令,必须设置 SelectCommand 属性,这是最低的要求。SelectCommand 所检索的表架构确定自动生成的 INSERT、UPDATE 和 DELETE 语句的语法。如果在自动生成插入、更新或删除命令后修改
SelectCommand 的 CommandText,则可能会发生异常。如果已修改的 SelectCommand.CommandText 所包含的架构信息与自动生成插入、更新或删除命令时所使用的 SelectCommand.CommandText 不一致,则以后对 DataAdapter.Update 方法的调用可能会试图访问 SelectCommand 引用的当前表中已不存在的列,并且会引发异常。可以通过调用 CommandBuilder 的 RefreshSchema 方法来刷新 CommandBuilder
用来自动生成命令的架构信息!
最后,我在代码里面加入了,
SqlCommandBuilder ss = new SqlCommandBuilder(da);
ss.RefreshSchema();/
/成功的解决了删除的时候所引发的异常:
看来,要学习的东西还有很多啊!这么简单的问题居然困扰了我半天时间!!!加油!
Fighting!!
相关文章推荐
- OleDbDataAdapter 的Update语句执行时提示“insert into语法错误”解决方法
- OleDbDataAdapter 的Update语句执行时提示“insert into语法错误”解决方法
- EF(Entity Framework)发生错误”正在创建模型,此时不可使用上下文“的解决办法。 正在创建模型,此时不可使用上下文。如果在 OnModelCreating 方法内使用上下文或如果多个线程同时访问同一上下文实例,可能引发此异常。请注意不保证 DbContext 的实例成员和相关类是线程安全的。 临时解决了这个问题,在Context的构造函数中,禁用了自动初始化:
- cocos2d-x调用scheduleUpdate()不执行update()方法的解决办法
- 控制台应用程序中调用CFileException 的GetErrorMessage方法时出现“Debug Assertion Failed”错误时的解决办法
- cocos2d-x调用scheduleUpdate()不执行update()方法的解决办法【转】
- cocos2d-x调用scheduleUpdate()不执行update()方法的解决办法
- cocos2d-x调用scheduleUpdate()不执行update()方法的解决办法
- cocos2d-x调用scheduleUpdate()不执行update()方法的解决办法
- 【Hibernate错误解决办法】Could not execute JDBC batch update; Data too long for column 'name' at row 1
- 在使用EF时调用DBFUNCTION扩展方法时,发生ENTITYCOMMANDEXECUTIONEXCEPTION 异常的解决办法
- 使用innodb_data_file_path修改数据文件位置,发生The server quit without updating PID file错误的解决原因及方法。
- 关于IE7打开任何网页弹出[未处理的异常('对象不支持此属性或方法')发生在iexplorer.exe]错误调试框的解决办法
- DataWindow调用存储器--SQLSTATE=22005--对于造型说明无效的字符值唯一解决方法[原创]
- cocos2d-x调用scheduleUpdate()不执行update()方法的解决办法
- 跨应用程序调用WebService发生错误的解决办法之一
- cocos2d-x调用scheduleUpdate()不执行update()方法的解决办法
- 当表中没有主键,用Adapter.Update方法的解决办法
- cocos2d-js:调用scheduleUpdate()不执行update()方法的解决办法
- 跨应用程序调用WebService发生错误的解决办法之一