mysql单字段更新全字段更新_疑问: 数据库进行更新时 当数据数据相同时 全字段更新和单字段更新是否有区别...

楼上大致正确,但是

1.前者也是通用的,但要多写一些 setXXX 的代码;

2.第二种方式在并发情况下容易导致前面的update失效,除非整个过程加锁:

请求1:

update Student set name="李四";

请求2:

update Student set name="张三",sex=0,weight="120" where id='123';

期望结果:

name="李四",sex=0,weight="120" where id='123'

实际结果:

"张三",sex=0,weight="120" where id='123'

原因:

请求2 setXXX 时,请求1正在执行SQL语句update1,这时候MySQL会加锁。

等到update1执行完后,请求2的SQL语句update2再执行,导致原本update1修改后的

name="李四"又被update2改回了name="张三"。

所以如果要用完整更新,请求2必须在setXXX前加锁,让update1在update2完成后才执行,这样才能避免并发情况下导致前面的update失效的问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值