zoukankan      html  css  js  c++  java
  • 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之间迁移时遇到问题,应尽可能保证代码简单粗暴,尽可能将一些“逻辑”拆出来,比如在由程序来计算列“最终”的更新值,即可完全避免以上困惑和踩坑。

    =======================================

  • 相关阅读:
    f5和ctrl+f5之浏览器缓存机制
    一次简单的http请求会碰撞出什么火花
    javascript的数据类型
    javascript语法规范
    javascript(ECMAScript)
    overflow:hidden可以将页面溢出内容隐藏起来
    抽屉新热榜头部实现
    数据分析
    抽屉页面设计
    position(relative)
  • 原文地址:https://www.cnblogs.com/TeyGao/p/6651175.html
Copyright © 2011-2022 走看看