UPDATE语句中SET部分列赋值的先后顺序有影响么?
Posted 笑东风
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了UPDATE语句中SET部分列赋值的先后顺序有影响么?相关的知识,希望对你有一定的参考价值。
昨天研发同事问我个问题,UPDATE语句中SET部分列赋值的先后顺序会影响结果么?以前没考虑过这个问题,因为通常我们都会UPDATE时给列赋予一个确定的值,而不是一个依赖于其他列的值。
测试环境:
DROP TABLE TB1001; CREATE TABLE TB1001 ( ID INT PRIMARY KEY, C1 INT, C2 INT ); INSERT INTO TB1001 ( ID, C1, C2 ) SELECT 1,1,1 UNION SELECT 2,1,1;
更新语句为:
UPDATE TB1001 SET C2=CASE WHEN C1=1 THEN 11 ELSE 22 END, C1=2 WHERE ID=1; UPDATE TB1001 SET C1=2, C2=CASE WHEN C1=1 THEN 11 ELSE 22 END WHERE ID=2;
首先在SQL Server 2012上进行,更新后数据为:
在mysql 5.6.26上运行,更新后的数据为:
测试结论:
在SQL Server 2012中,UPDATE 语句SET部分列顺序不会影响最终结果;
在MySQL 5.6版本中,UPDATE 语句SET部分列顺序会影响最终结果;
因此建议研发同志,为提高程序的“兼容性”,避免在MySQL和SQL Server之间迁移时遇到问题,应尽可能保证代码简单粗暴,尽可能将一些“逻辑”拆出来,比如在由程序来计算列“最终”的更新值,即可完全避免以上困惑和踩坑。
=======================================
以上是关于UPDATE语句中SET部分列赋值的先后顺序有影响么?的主要内容,如果未能解决你的问题,请参考以下文章
sql server 2005多表连接查询,去除部分列不查询
PostgreSQL之INSERT,DELETE,UPDATE
MySQL中INSERT,UPDATE和REPLACE的区别与用法
java中创建对象了,显示初始化值和构造函数初始化对象的区别?先后执行顺序是啥?