一条 SQL 把整表数据改崩,MySQL 还没报错?我懵了!

“我明明写了条件,怎么全表都被更新了?!”
“更离谱的是,MySQL 还没报错,执行成功了!”

这不是段子,这是今天真实发生在我身上的故事。

01 一条“看似正常”的 SQL

事情是这样的:

一位开发小哥想更新一张任务调度表,将某些的任务状态改成 -2,于是他写了这么一条 SQL:

UPDATE wl_quotes_scheduler.xxl_job_infoSET trigger_status =-2 AND job_group NOTIN(61,58);

执行完一看,执行成功:


02 为什么没报错?MySQL:语法没错,是你用错了

我们来把这条 SQL 拆开看:

SET trigger_status =-2 AND job_group NOTIN(61,58)

注意,这里用了一个 AND,但它不是在 WHERE 子句里,而是在 SET 子句里

MySQL 一看:
“哦,你在赋值一个布尔表达式?没问题,合法!”

于是它把这条语句理解成了:

SET trigger_status =(-2AND(job_group NOTIN(61,58)))

所以整张表的 trigger_status 被批量改了 。


03 没写 WHERE,全表都更新!

更惨的是,这条 SQL 没有 WHERE 子句

也就是说,所有行都参与了更新,只是值被“布尔运算”洗了一遍。


04 小结:SQL 不报错,不代表没坑

  • MySQL 允许在 SET 子句里写表达式,包括布尔表达式

  • AND 在 SET 里不是“条件”,而是“运算”

  • 没有 WHERE 子句,就是全表更新

  • 布尔值 TRUE/FALSE 在数值上下文里是 1/0


一开始我也纳闷这个用法到底有没有问题,有没有语法错误,截图发到微信群里问其他小伙伴,发现也有一些小伙伴说会报错啥的,大家有疑问的话大家也可以自己找个数据库执行类似的脚本试试。


— END —

如果你觉得这种“小坑”也值得警惕,欢迎点个「赞」和「在看」,转发给那个总是手写 SQL 的同事,帮他少踩一个坑。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小博测试成长之路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值