SQL的update语句更新顺序的坑

文章目录

环境

  • Windows 11 专业版
  • XAMPP v3.3.0
    • MySQL Ver 15.1
  • MySQL Workbench 8.0 CE

背景

t1 中有三列 c1c2c3

  • c1 :总名额
  • c2 :已报名数量
  • c3 :替补名额

其中,"总名额"包含了"替补名额"。比如,一场比赛A(id为1)的正式名额是14,而总名额是20,其中包含了6个替补名额。到报名截止时间,实际报名数量是18人。也就是说:

  • c1 = 20
  • c2 = 18
  • c3 = 6

t1 如下:

在比赛开始前,需要处理替补人员。对于本例,只有14个正式名额,因此需要把4个替补人员劝退( c2 会变成14)。

接下来,需要把替补名额修改为0,并把总名额修改为14。

SQL

从上面的需求可知,对于"把替补名额修改为0,并把总名额修改为14",只需要一个update语句,把 c3 清零,并把 c1 改为 c1 - c3

sql 复制代码
update t1 set c3 = 0, c1 = c1 - c3 where id = 1;

看上去没有问题,然而,运行SQL后,表 t1 内容如下:

可见, c1 的值没有变化!

这是因为,update语句在更新数据时,按照"从左到右"的顺序依次更新,并且使用的是"最新的值"。

也就是说,我们期望把 c1 修改为 c1 - c3 ,也就是 20 - 6 ,值为 14 ,然而,在此操作之前, c3 已经被清零了,所以, c1 的值实际上并没有发生变化。

这个问题让我困惑了半天,我一直以为是我把SQL语句哪里写错了(因为我使用了ThinkPHP框架,没有用原生SQL),后来才醒悟过来,是我对SQL的语义理解有偏差。

知道了问题产生的原因,那么问题也就迎刃而解了。

最简单的解决办法,就是交换一下更新的顺序:

sql 复制代码
update t1 set c1 = c1 - c3, c3 = 0 where id = 1;

这样, c1c3 都能得到期望值了。

总结

update语句在更新数据时,按照"从左到右"的顺序依次更新,并且使用的是"最新的值",所以一定要小心顺序,别搞错了。

相关推荐
feng68_2 小时前
MySQL集群高可用-MHA
linux·运维·数据库·mysql·集群技术
dyxal2 小时前
SQLite扩展加载详解:用`SELECT load_extension()`为数据库装上“外挂”
数据库·sqlite
sunwenjian8862 小时前
redis安装与部署
数据库·redis·缓存
干啥啥不行,秃头第一名2 小时前
实战:用Python开发一个简单的区块链
jvm·数据库·python
登高去梯2 小时前
mysql的下载、安装、环境配置;navicat17的安装
数据库·mysql
qwehjk20082 小时前
使用Scikit-learn构建你的第一个机器学习模型
jvm·数据库·python
m0_560396472 小时前
用Python创建一个Discord聊天机器人
jvm·数据库·python
pupudawang2 小时前
Spring Boot 各种事务操作实战(自动回滚、手动回滚、部分回滚)
java·数据库·spring boot
酿情师2 小时前
2026软件系统安全赛初赛MISC--steganography
数据库·安全