首页 > 数据库技术 > 详细

MySQL的Update语句Set顺序问题

时间:2014-03-26 17:03:13      阅读:430      评论:0      收藏:0      [点我收藏+]
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的结果:
bubuko.com,布布扣

(2)MySQL的结果:
bubuko.com,布布扣


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
where tag=3;

select * from test;

(1)sqlserver2014的结果:
bubuko.com,布布扣

(2)MySQL的结果
bubuko.com,布布扣


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


MySQL的Update语句Set顺序问题,布布扣,bubuko.com

MySQL的Update语句Set顺序问题

原文:http://blog.csdn.net/sarahcla/article/details/22157431

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!