设为首页 加入收藏

TOP

MySQL的Update语句Set顺序问题
2014-11-24 03:26:20 来源: 作者: 【 】 浏览:3
Tags:MySQL Update 语句 Set 顺序 问题
1. 测试一 create table test(id int, tag int, num int);
insert into test (id, tag, num) values(1, 1, 1), (2,2, 2), (3,3,3);
update test set tag = 4, num=case when tag=4 then 4 else 3 end where tag=3;
select * from test;
(1)sqlserver2014的结果: \

(2)MySQL的结果: \


2. 测试二:更换set语句的顺序 create table test(id int, tag int, num int);

insert into test (id, tag, num) values(1, 1, 1), (2,2, 2), (3,3,3);
update test set num=case when tag=4 then 4 else 3 end, tag = 4< http://www.2cto.com/kf/ware/vc/" target="_blank" class="keylink">vc3Ryb25nPgp3aGVyZSB0YWc9MzsKPGJyPgpzZWxlY3QgKiBmcm9tIHRlc3Q7Cjxicj4KCjxzdHJvbmc+o6gxo6lzcWxzZXJ2ZXIyMDE0tcS94bn7o7o8L3N0cm9uZz4KPGltZyBzcmM9"https://www.cppentry.com/upload_files/article/57/1_1igbp__.jpg" alt="\">

(2)MySQL的结果


结论:
(1)MySQL的update语句,set列的顺序是有关系的,后面列的计算是以前面列的结果为基础的,即从左向右评估;
(2)SQLServer的update语句,set的顺序无关,所有的更改都是基于之前取出的快照;


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇mysql修改表 下一篇MySQL的C++封装

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·python数据分析岗的 (2025-12-25 10:02:21)
·python做数据分析需 (2025-12-25 10:02:19)
·成为一个优秀的pytho (2025-12-25 10:02:16)
·Java后端面试实习自 (2025-12-25 09:24:21)
·Java LTS版本有哪些 (2025-12-25 09:24:18)