zoukankan      html  css  js  c++  java
  • Oracle行转列,pivot函数和unpivot函数

    pivot函数:行转列函数:
      语法:pivot(任一聚合函数 for 需专列的值所在列名 in (需转为列名的值));
    unpivot函数:列转行函数:
      语法:unpivot(新增值所在列的列名 for 新增列转为行后所在列的列名 in (需转为行的列名));
    执行原理:将pivot函数或unpivot函数接在查询结果集的后面。相当于对结果集进行处理。

    转换示例:

    1.原始表数据:
      sql语句:select * from T_PIVOT_TEST_1 ;

        

    2.用pivot函数进行行转列。其中用聚合函数对数据列进行求值,将th列中的值’COL_1‘,’COL_2‘,‘COL_3’转化为列名,并为其加上别名。
      sql语句:select * from T_PIVOT_TEST_1
        pivot (sum(er) for th in ('COL_1' as 第一列,'COL_2'as 第二列 ,'COL_3' as 第三列));
    转换后结果图:

        

    3.用nupivot函数进行列转行。在原sql语句上再加上unpivot函数,将列再转为行,在unpivot函数中,aa与bb为新增的列名,分别表示由列转换为行后的数据所在的列名和数据所在的列名。
    sql语句:select * from T_PIVOT_TEST_1
    pivot (sum(er) for th in ('COL_1' as 第一列,'COL_2'as 第二列 ,'COL_3' as 第三列))
    unpivot ( aa for bb in(第一列,第二列,第三列));
    转换后结果图:

        

  • 相关阅读:
    减少注入元
    浅谈微服务基建的逻辑
    Linux系统Java环境安装配置
    ASP.NET Core 依赖注入
    C#并发编程实例讲解-概述(01)
    Linux系统从安装开始
    关于C#获取动态的时间差函数
    SQL Server 存储过程
    jQuery选择器大全(48个代码片段+21幅图演示)
    对齐方式
  • 原文地址:https://www.cnblogs.com/waynelo/p/9869020.html
Copyright © 2011-2022 走看看