您的位置:首页 > 其它

对于调用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!!

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐