聚合不应出现在 update 语句的集合列表中_MySQL UPDATE 语句一个“经典”的坑

  • 有问题的SQL语句
  • why?
  • 倒回去再重试验一把

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

fb2fab4204d0b194206b81bffc6d6ba2.png

img

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

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

有问题的SQL语句

c2c30597849bda481dcc756b783c6c58.png

img

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

c2c30597849bda481dcc756b783c6c58.png

img

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

c0484f2b738f78b18875014e776a360e.png

img

可以看到,结果并不像这位开发同学说的“好像没有效果”,实际上是有效果的:

fc169bdfeb6d5fb9820f399878d00829.png

img

why?

看起来,语法是完全没有问题,翻了翻MySQL官方文档的update语法:

464ad2b51b88bd54c5b0f959837cbeca.png

img

看到assignment_list的格式是以逗号分隔的col_name=value列表,一下子豁然开朗,开发同学想要的多字段更新语句应该这样写:

6288ff69a27d6872308fcc3a1d00a815.png

img

倒回去再重试验一把

53f6afca3e58e42695a32bcf28999e9e.png

img

果然,这下得到了想要的结果!

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

**后记 :**后面等有空的时候,又回过头来看了一下,为什么使用“AND”分隔的时候,会出现owner_code=0的奇怪结果?多次尝试之后发现:

6ce5fcbaec2407054df5b3a538f16631.png

img

等价于:

40d1f9d89e0818bb0b6efa319028800c.png

img

而 ('43212' and owner_name='李四') 是一个逻辑表达式,而这里不难知道owner_name并不是‘李四’。因此,这个逻辑表达式的结果为 false , false在MySQL中等价于0!

来源:http://tinyurl.com/yxm8j7q7


:-D 搜索微信号(ID:芋道源码),可以获得各种 Java 源码解析、原理讲解、面试题、学习指南。

:-D 并且,回复【书籍】后,可以领取笔者推荐的各种 Java 从入门到架构的 100 本书籍。

:-D 并且,回复【技术群】后,可以加入专门讨论 Java、后端、架构的技术群。

2770e93a1c0a155c8c269ef3139de406.png

来吧,骚年~

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值