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 vc 3Ryb25nPgp3aGVyZSB0YWc9MzsKPGJyPgpzZWxlY3QgKiBmcm9tIHRlc3Q7Cjxicj4KCjxzdHJvbmc+o6gxo6lzcWxzZXJ2ZXIyMDE0tcS94bn7o7o8L3N0cm9uZz4KPGltZyBzcmM9"http://HdhCmsTest2cto测试数据/uploadfile/Collfiles/20140327/2014032709015710.jpg" alt="\"> (2)MySQL的结果 结论: (1)MySQL的update语句,set列的顺序是有关系的,后面列的计算是以前面列的结果为基础的,即从左向右评估; (2)SQLServer的update语句,set的顺序无关,所有的更改都是基于之前取出的快照;
查看更多关于MySQL的Update语句Set顺序问题 - mysql数据库栏目 - 自的详细内容...