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

  • 相关阅读:
    firefox配置
    安装gstreamer开发环境
    linux下批量替换文件内容(转)
    iptables详细教程:基础、架构、清空规则、追加规则、应用实例(转)
    iptables 使用
    如何用iptables实现NAT(转)
    Python 练习题
    Python unittest 参数化
    Python Logging模块
    Python 多进程
  • 原文地址:https://www.cnblogs.com/yeminglong/p/2231321.html
Copyright © 2011-2022 走看看