SQL 行转列,列转行

SQL 行转列,列转行

行列转换在作报表分析时仍是常常会遇到的,今天就说一下如何实现行列转换吧。sql

行列转换就是以下图所示两种展现形式的互相转换函数

SQL行列转换.png

行转列

假如咱们有下表: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
相关文章
相关标签/搜索