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(第一列,第二列,第三列));
    转换后结果图:

        

  • 相关阅读:
    牛客编程巅峰赛S1第8场
    【杭电多校4】2020 Multi-University Training Contest 4
    2020牛客暑期多校训练营(第七场)
    DFS【搜索1】
    2020牛客暑期多校训练营(第六场)
    2020牛客暑期多校训练营(第五场)
    大数模板
    分布式前后端分离项目开发步骤
    Linux 查看服务器硬件信息
    写在前面
  • 原文地址:https://www.cnblogs.com/waynelo/p/9869020.html
Copyright © 2011-2022 走看看