对于不返回任何键列信息的 SelectCommand 不支持 UpdateCommand 的动态 SQL 生成。

在尝试使用SqlCommandBuilder动态生成UpdateCommand时遇到了'对于不返回任何键列信息的SelectCommand不支持UpdateCommand的动态SQL生成'的错误。由于表中缺少主键,直接修改数据库结构并不实际。通过查阅资料,尝试了蓝色理想提供的解决方案,即在DataTable中设置Primarykey,但未成功。最终,通过手动定义UpdateCommand解决了问题。总结了解决此类问题的两种方法:1. 定义表的主键;2. 明确定义SqlDataAdapter的UpdateCommand。
摘要由CSDN通过智能技术生成

 
UpdateCommand 的动态 SQL 生成”问题,关键代码如下(C#):

 

........
string emailSql="select email,validFlag from emailMe";
DataSet emailAdd=new DataSet();
SqlDataAdapter emailAdapter=new SqlDataAdapter(emailSql,myConn);
SqlCommandBuilder cb=new SqlCommandBuilder(emailAdapter);
emailAdapter.Fill(emailAdd,"address");
myConn.Close();
......//修改myDs数据
emailAdapter.Update(emailAdd,"address");

emailMe的结构是这样的:
email nvarchar 100
validFlag int

运行这段代码,竟然出现了“对于不返回任何键列信息的 SelectCommand 不支持 UpdateCommand 的动态 SQL 生成”错误。想了一下,是因为emailMe表中没有定义主键字段,所以SqlCommandBuilder无法为SqlDataAdapter自动生成需要的UpdateCommand。修改表的定义,将email字段定义为主键问题当然可以解决,但是因为库里表太多了,逐一修改几乎不可能,有没有其他办法呢?


在网上搜了一下,发现有位网名“蓝色理想”的朋友给出了一个解决方案(ht

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值