资讯专栏INFORMATION COLUMN

SQL 行转列,列转行

DDreach / 745人阅读

摘要:行转列,列转行行列转换在做报表分析时还是经常会遇到的,今天就说一下如何实现行列转换吧。列转行假设我们有下表语文数学英语通过即可得到如下结果我们也可以使用下面方法得到同样结果语文语文数学数学英语英语

SQL 行转列,列转行

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

行列转换就是如下图所示两种展示形式的互相转换

行转列

假如我们有下表:

SELECT *
FROM student
PIVOT (
    SUM(score) FOR subject IN (语文, 数学, 英语)
)

通过上面 SQL 语句即可得到下面的结果

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 简单直观。

列转行

假设我们有下表 student1

SELECT *
FROM student1
UNPIVOT (
    score FOR subject IN ("语文","数学","英语")
)

通过 UNPIVOT 即可得到如下结果:

我们也可以使用下面方法得到同样结果

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

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/62904.html

相关文章

  • SQL 转行

    摘要:行转列,列转行行列转换在做报表分析时还是经常会遇到的,今天就说一下如何实现行列转换吧。列转行假设我们有下表语文数学英语通过即可得到如下结果我们也可以使用下面方法得到同样结果语文语文数学数学英语英语 SQL 行转列,列转行 行列转换在做报表分析时还是经常会遇到的,今天就说一下如何实现行列转换吧。 行列转换就是如下图所示两种展示形式的互相转换 showImg(https://segment...

    Meathill 评论0 收藏0
  • SQL 转行

    摘要:行转列,列转行行列转换在做报表分析时还是经常会遇到的,今天就说一下如何实现行列转换吧。列转行假设我们有下表语文数学英语通过即可得到如下结果我们也可以使用下面方法得到同样结果语文语文数学数学英语英语 SQL 行转列,列转行 行列转换在做报表分析时还是经常会遇到的,今天就说一下如何实现行列转换吧。 行列转换就是如下图所示两种展示形式的互相转换 showImg(https://segment...

    Donald 评论0 收藏0
  • SQL 转行

    摘要:行转列,列转行行列转换在做报表分析时还是经常会遇到的,今天就说一下如何实现行列转换吧。列转行假设我们有下表语文数学英语通过即可得到如下结果我们也可以使用下面方法得到同样结果语文语文数学数学英语英语 SQL 行转列,列转行 行列转换在做报表分析时还是经常会遇到的,今天就说一下如何实现行列转换吧。 行列转换就是如下图所示两种展示形式的互相转换 showImg(https://segment...

    shiina 评论0 收藏0
  • SQL 转行

    摘要:行转列,列转行行列转换在做报表分析时还是经常会遇到的,今天就说一下如何实现行列转换吧。列转行假设我们有下表语文数学英语通过即可得到如下结果我们也可以使用下面方法得到同样结果语文语文数学数学英语英语 SQL 行转列,列转行 行列转换在做报表分析时还是经常会遇到的,今天就说一下如何实现行列转换吧。 行列转换就是如下图所示两种展示形式的互相转换 showImg(https://segment...

    chunquedong 评论0 收藏0
  • Python中xlsx文件转置操作详解(转行)

      在很多的时候,我们在处理excel表格的时候,经常性的会遇到各种各样的问题,比如表格格式不对,或者是不是我们想要的,那么,这个时候我们就会要学习使用到python了,下面小编就给大家详细的来做一个解答。  1.原始数据是这样的  2.脚本如下:  importpandasaspd   df=pd.read_excel(r'E:\untitled1\带宽测试\temp.xlsx'...

    89542767 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<