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

  • 相关阅读:
    0505.Net基础班第十四天(winform基础)
    0505.Net基础班第十三天(面向对象多态)
    Z-index
    div的padding和margin
    隐藏div,文本框角圆滑,消除外边框
    页面加载完成之后运行方法里的内容,隐藏标签,判断字符串里面是否包含某个字符
    CSS命令
    漂浮
    电子时钟
    用二维数组存数据(学科成绩、总分以及平均值)
  • 原文地址:https://www.cnblogs.com/yeminglong/p/2231321.html
Copyright © 2011-2022 走看看