行列转换在作报表分析时仍是常常会遇到的,今天就说一下如何实现行列转换吧。sql
行列转换就是以下图所示两种展现形式的互相转换函数
假如咱们有下表:spa
SELECT * FROM student PIVOT ( SUM(score) FOR subject IN (语文, 数学, 英语) )
经过上面 SQL 语句便可获得下面的结果code
PIVOT 后跟一个聚合函数来拿到结果,FOR 后面跟的科目是咱们要转换的列,这样的话科目中的语文、数学、英语就就被转换为列。IN 后面跟的就是具体的科目值。图片
固然咱们也能够用 CASE WHEN 获得一样的结果,就是写起来麻烦一点。数学
SELECT name, MAX( CASE WHEN subject='语文' THEN score ELSE 0 END) AS "语文", MAX( CASE WHEN subject='数学' THEN score ELSE 0 END) AS "数学", MAX( CASE WHEN subject='英语' THEN score ELSE 0 END) AS "英语" FROM student GROUP BY name
使用 CASE WHEN 能够获得和 PIVOT 一样的结果,没有 PIVOT 简单直观。it
假设咱们有下表 student1class
SELECT * FROM student1 UNPIVOT ( score FOR subject IN ("语文","数学","英语") )
经过 UNPIVOT 便可获得以下结果:方法
咱们也能够使用下面方法获得一样结果im
SELECT NAME, '语文' AS subject , MAX("语文") AS score FROM student1 GROUP BY NAME UNION SELECT NAME, '数学' AS subject , MAX("数学") AS score FROM student1 GROUP BY NAME UNION SELECT NAME, '英语' AS subject , MAX("英语") AS score FROM student1 GROUP BY NAME