违反并发性: UpdateCommand影响了预期 1 条记录中的 0 条

5 篇文章 0 订阅

c#更新数据库记录。有两个表A,B。A是主表,B是从表。联合更新B的数据时总出现标题的错误。

我有3个这种从属关系的表,另外两个都是没问题,就这个出问题。而且我都在SQL执行过相应的SQL语句,是没问题的。


查资料,都说UpdateCommand要有主键,如果主键是自动增长的要声明,。。。。

都不是我的问题所在。后来发现跟数据表里面字段的类型有关。


如果更新数据库进行条件比较的字段有float类型的要注意了。调试c#程序发现float取出来的值是正确的,数据后面没有补一些其它的值,但是在数据库里面确实进行了补位。例如 float ff=3.14; c#里面取出来也是3.14,但是在数据库里面可能就是3.1400012。

所以float字段进行比较就会出现上面的错误。因为数据库找不到相应的数据,所以报错。


解决方式,把数据库字段类型是float的改为decimal类型,就可以解决问题。decimal因为有小数位数限制,所以数值后面不会有很多意想不到的值。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值