zoukankan      html  css  js  c++  java
  • SQL查询案例:列行转换[列转行, 使用 UNION ALL 处理]

    SQL查询案例:列行转换[列转行, 使用 UNION ALL 处理]

    在行列转换的处理之后, 有时候会遇到,要列行装换的

    CREATE TABLE TestColRow (
    name   VARCHAR(10),
    东 INT,
    南 INT,
    西 INT,
    北 INT
    );

    INSERT INTO TestColRow
    VALUES ('张三', 1, 2, 3, 4);

    INSERT INTO TestColRow
    VALUES ('李四', 5, 6, 7, 8);

    使用 UNION ALL 的方式处理

    SELECT
    name, '东' AS Place, 东 AS Value
    FROM
    TestColRow
    UNION ALL
    SELECT
    name, '南' AS Place, 南 AS Value
    FROM
    TestColRow
    UNION ALL
    SELECT
    name, '西' AS Place, 西 AS Value
    FROM
    TestColRow
    UNION ALL
    SELECT
    name, '北' AS Place, 北 AS Value
    FROM
    TestColRow

    name       Place Value
    ---------- ----- -----------
    张三         东               1
    李四         东               5
    张三         南               2
    李四         南               6
    张三         西               3
    李四         西               7
    张三         北               4
    李四         北               8

    使用 UNPIVOT 的处理方式


    SELECT
    ROW_NUMBER() OVER (ORDER BY (SELECT 0)) AS id,
    *
    FROM
    TestColRow
        UNPIVOT( Value FOR Place IN ([东],[南],[西],[北]) )
    AS a

    结果:

    id   name Value Place
    ---- ----- ------ ------
    1    张三   1       东
    2    张三   2       南
    3    张三   3       西
    4    张三   4       北
    5    李四   5       东
    6    李四   6       南
    7    李四   7       西
    8    李四   8       北

    如果这篇文章对您有帮助,您可以打赏我

    技术交流QQ群:15129679

  • 相关阅读:
    关闭webstorm自动保存,并显示文件未保存标识
    ionic1.3.3 下拉刷新 上拉加载更多
    纯css导航下划线跟随效果【转载】
    wpf获取模板化控件中的动画。
    wpf中dropdownButton控件下拉居中。。。
    C#综合揭秘——深入分析委托与事件
    反射
    多线程,异步
    wcf,socket,数据传输方式
    面向对象五大原则三个基本特征
  • 原文地址:https://www.cnblogs.com/yeminglong/p/2231321.html
Copyright © 2011-2022 走看看