mysql update 没反应_MySQL Update语句一个非常经典的“坑”

本文介绍了在MySQL中遇到的一个经典问题,即使用`AND`连接更新多个字段时导致更新失败或产生意外结果。正确的方式应使用逗号分隔字段。通过案例分析和错误演示,解释了为何使用`AND`会导致owner_code字段变为0,并提供了正确更新语句的示例。
摘要由CSDN通过智能技术生成

点击关注上方“SQL数据库开发”,

设为“置顶或星标”,第一时间送达干货

起因

最近好几次有开发同学在钉钉上问我,比如下图:

5beb9887a34fa406e20f3089e2d4e208.png

问题归纳起来就是:在MySQL里面update一条记录,语法都正确的,但记录并没有被更新…

结论

小结:在一条UPDATE语句中,如果要更新多个字段,字段间不能使用“AND”,而应该用逗号分隔。

现象

刚遇到这个问题的时候,我拿到这条语句直接在测试库里面执行了一把,发现确实有问题,但和开发描述的还是有区别,这里我用测试数据来模拟下:

有问题的SQL语句:update apps set owner_code='43212' and owner_name='李四' where owner_code='13245' and owner_name='张三';

执行之前的记录是这样的:

8930fc1ac82d501ac79e0ad6f67e40cb.png

执行之后的记录是这样的:</

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值