网站地图    收藏   

主页 > 后端 > mysql数据库 >

MySQL的Update语句Set顺序问题 - mysql数据库栏目 - 自

来源:自学PHP网    时间:2015-04-16 10:51 作者: 阅读:

[导读] 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 ta...

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"http://www.2cto.com/uploadfile/Collfiles/20140327/2014032709015710.jpg" alt="\">

(2)MySQL的结果


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


自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论