开发者社区> mush2017> 正文

每次这样写 Update 语句,怕是离开除不远了 !

简介: 每次这样写 Update 语句,怕是离开除不远了 !
+关注继续查看

1起因

最近,好几次有开发同学问这样的SQL问题,如下图:

image.png

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

2结论

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

3现象

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

有问题的SQL语句:

update apps set owner_code='43212' and owner_name='李四' where owner_code='13245' and owner_name='张三';

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

image.png

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

image.png

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

owner_name的值没有变,但owner_code变成了0!

4why? 分析

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

image.png

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

update apps set owner_code='43212' , owner_name='李四' where owner_code='13245' and owner_name='张三';

倒回去再重试验一把:

image.png

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

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

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

update apps set owner_code='43212' and owner_name='李四' where owner_code='13245' and owner_name='张三';

等价于:

update apps set owner_code=('43212' and owner_name='李四') where owner_code='13245' and owner_name='张三';

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


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
MySQL原理 - InnoDB引擎 - 行记录存储 - Off-page 列
MySQL原理 - InnoDB引擎 - 行记录存储 - Off-page 列
4 0
MySQL8.0.26 出现错误#1045
MySQL8.0.26 出现错误#1045
3 0
面向WEB开发的Docker(一)
Docker的优势很容易让Web开发人员所忽略。对于开发运维来说,它被认为太过技术性、没有必要。术语可能难以理解。教程从来没有解释如何在开发过程中使用Docker。在这里带大家一起来感受Docker在WEB开发中应用。
3 0
面向WEB开发的Docker(二):什么是Docker、镜像、编排?
什么是Docker容器?有什么的特点:轻量,在一台机器上运行的多个Docker容器可以共享这台机器的操作系统内核;它们能够迅速启动,只需占用很少的计算和内存资源。镜像是通过文件系统层进行构造的,并共享一些公共文件。这样就能尽量降低磁盘用量,并能更快地下载镜像。
5 0
千万级购物车系统缓存架构方案
本文主要介绍redis在千万级系统中设计架构方案,包括主架构设计、缓存一致性方案、大value处理方案和redis限流和故障恢复降级
11 0
面向WEB开发的Docker(四):启动MySQL数据库
在本文中,将来学习如何使用Docker CLI和Docker compose启动MySQL容器。
7 0
面向WEB开发人员的Docker(五):部署开发WordPress
前面介绍了Docker的一些基本知识和使用,对于新技术或者新系统想去尝试运行起来,Docker是一个最佳的选择,上手容易,抛弃也容易,如果系统或者应用运行起来后不需要了可以直接删除即可,对宿主机没有任何的影响,也不会受到宿主机环境的干扰。本文将分享如何使用Docker构建WordPress环境,并运行起来。
4 0
Node.js使用数据库LevelDB:超高性能kv存储引擎
Node.js被设计用来做快速高效的网络I/O。它的事件驱动流使其成为一种智能代理的理想选择,通常作为后端系统和前端之间的粘合剂。Node的设计初衷就是为了实现这一目的,但与此同时,它已成功用于构建传统的Web应用程序:一个HTTP服务器,提供为HTML页面或JSON消息响应,并使用数据库存储数据。
3 0
分布式缓存详解
分布式缓存详解
4 0
批处理框架 Spring Batch,数据迁移量过大如何保证内存?
批处理框架 Spring Batch,数据迁移量过大如何保证内存?
5 0
+关注
243
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载