行转列,列转行是我们在开发过程中经常碰到的问题。

1、行转列一般通过CASE WHEN 语句来实现
2、也可以通过 SQL SERVER 2005 新增的运算符PIVOT来实现。
用传统的方法,比较好理解。层次清晰,而且比较习惯。
但是PIVOT 、UNPIVOT提供的语法比一系列复杂的SELECT…CASE 语句中所指定的语法更简单、更具可读性。下面我们通过几个简单的例子来介绍一下列转行、行转列问题。

一、行转列

我们首先先通过一个老生常谈的例子,学生成绩表(下面简化了些)来形象了解下行转列

CREATE  TABLE [StudentScores]
([UserName]         NVARCHAR(20),        --学生姓名[Subject]          NVARCHAR(30),        --科目[Score]            FLOAT,               --成绩
)

插入数据

INSERT INTO [StudentScores] SELECT 'Nick', '语文', 80
INSERT INTO [StudentScores] SELECT 'Nick', '数学', 90
INSERT INTO [StudentScores] SELECT 'Nick', '英语', 70
INSERT INTO [StudentScores] SELECT 'Nick', '生物', 85
INSERT INTO [StudentScores] SELECT 'Kent', '语文', 80
INSERT INTO [StudentScores] SELECT 'Kent', '数学', 90
INSERT INTO [StudentScores] SELECT 'Kent', '英语', 70
INSERT INTO [StudentScores] SELECT 'Kent', '生物', 85

如果我想知道每位学生的每科成绩,而且每个学生的全部成绩排成一行,这样方便我查看、统计,导出数据

1、case when 方式

SELECT UserName, MAX(CASE Subject WHEN '语文' THEN Score ELSE 0 END) AS '语文',MAX(CASE Subject WHEN '数学' THEN Score ELSE 0 END) AS '数学',MAX(CASE Subject WHEN '英语' THEN Score ELSE 0 END) AS '英语',MAX(CASE Subject WHEN '生物' THEN Score ELSE 0 END) AS '生物'
FROM dbo.[StudentScores]
GROUP BY UserName

查询结果如图所示,这样我们就能很清楚的了解每位学生所有的成绩了

2、PIVOT方式

SELECT * FROM [StudentScores] /*数据源*/
AS P
PIVOT
(SUM(Score/*行转列后 列的值*/) FOR p.Subject/*需要行转列的列*/ IN ([语文],[数学],[英语],[生物]/*列的值*/)
) AS T

另举一例做解释:

SELECT [星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日]
--这里是PIVOT第三步(选择行转列后的结果集的列)这里可以用“*”表示选择所有列,也可以只选择某些列(也就是某些天),通过TBL来定义列的别名FROM WEEK_INCOME--这里是PIVOT第二步骤(准备原始的查询结果,因为PIVOT是对一个原始的查询结果集进行转换操作,所以先查询一个结果集出来)这里可以是一个select子查询,--但为子查询时候要指定别名,否则语法错误PIVOT
(SUM(INCOME) for [week] in([星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日])
--这里是PIVOT第一步骤,也是核心的地方,进行行转列操作。
--聚合函数SUM表示你需要怎样处理转换后的列的值,是总和(sum),还是平均(avg)还是min,max等等。
--例如如果week_income表中有两条数据并且其week都是“星期一”,
--其中一条的income是1000,另一条income是500,那么在这里使用sum,行转列后“星期一”这个列的值当然是1500了。
--后面的for [week] in([星期一],[星期二]...)中 for [week]就是说将week列的值分别转换成一个个列,也就是“以值变列”。
--但是需要转换成列的值有可能有很多,我们只想取其中几个值转换成列,那么怎样取呢?
--就是在in里面了,比如我此刻只想看工作日的收入,在in里面就只写“星期一”至“星期五”
--(注意,in里面是原来week列的值,"以值变列")。总的来说,SUM(INCOME) for [week] in([星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日])这句的意思直译出来,
--就是说:将列[week]值为"星期一","星期二","星期三","星期四","星期五","星期六","星期日"分别转换成列,这些列的值取income的总和。)TBL
--别名一定要写

二、列转行

1、测试数据准备

CREATE TABLE ProgrectDetail
(ProgrectName         NVARCHAR(20), --工程名称OverseaSupply        INT,          --海外供应商供给数量NativeSupply         INT,          --国内供应商供给数量SouthSupply          INT,          --南方供应商供给数量NorthSupply          INT           --北方供应商供给数量
)INSERT INTO ProgrectDetail
SELECT 'A', 100, 200, 50, 50
UNION ALL
SELECT 'B', 200, 300, 150, 150
UNION ALL
SELECT 'C', 159, 400, 20, 320
UNION ALL


sql语句:

SELECT P.ProgrectName,P.Supplier,P.SupplyNum
FROM
(SELECT ProgrectName, OverseaSupply, NativeSupply,SouthSupply, NorthSupplyFROM ProgrectDetail
)T
UNPIVOT
(SupplyNum FOR Supplier IN(OverseaSupply, NativeSupply, SouthSupply, NorthSupply )
) P

结果:

SQL 行转列、列转行相关推荐

  1. sql行并列,列分行

    将一个字段","分割的数据进行多列展示: SELECT REGEXP_SUBSTR (T.TEXTBOOK_IDS,'[^,]+',1,LEVEL) TEXTBOOK_ID FRO ...

  2. SQL Server 行转列,列转行。多行转成一列

    一.多行转成一列(并以","隔开) 表名:A 表数据: 想要的查询结果: 查询语句: SELECT name ,value = ( STUFF(( SELECT ',' + val ...

  3. SQL 行转列 列转行 Oracle转置函数函数pivot、unpivot 解决wm_concat 没有排序

    https://www.cnblogs.com/mellowsmile/p/4642306.html HH 终风且暴,顾我则笑,谑浪笑敖,中心是悼. 终风且霾,惠然肯来,莫往莫来,悠悠我思. 博客园 ...

  4. SQL行转列,列转行

    我们都知道在sql查询中,union 是增行,join是增列,但是如果碰到需要行转列,列转行时,一味的使用 join来完成则会变的异常繁杂.如把一天24小时的行转换成列,则需要join24次,既不方便 ...

  5. SQL——行转列,列转行

    重温SQL--行转列,列转行 行转列,列转行是我们在开发过程中经常碰到的问题.行转列一般通过CASE WHEN 语句来实现,也可以通过 SQL SERVER 2005 新增的运算符PIVOT来实现. ...

  6. 使用case when,union all实现sql行转列、列转行

    以前有写过行转列,列转行的博客 具体见: https://blog.csdn.net/weixin_38653290/article/details/84639754 今天分享下使用case when ...

  7. SQL 行转列 和 列转行 整理

    SQL 列转行 和行转列 列转多行场景: ​ 表中的某个字段是由多个字符串拼接而成,需要按照每个拼接的字符串转换成多行,比如 :[手机品牌]字段里的内容是 小米,华为,苹果:按照这个几个类别进行分组: ...

  8. SQL行转列、列转行

    SQL行转列.列转行 这个主题还是比较常见的,行转列主要适用于对数据作聚合统计,如统计某类目的商品在某个时间区间的销售情况.列转行问题同样也很常见. 一.整理测试数据 create table wyc ...

  9. sqlserver中某列转成以逗号连接的字符串及逆转、数据行转列列转行

    Sql Server 列转逗号隔开的字符串 和 逆转 https://www.cnblogs.com/duanyuerui/p/7567692.html Sql server 中将数据行转列列转行(一 ...

  10. 死磕:SQL行转列汇总(全网最全最详细)

    SQL行转列汇总 阅读目录 一. 基础语法: 二. 典型实例 一. 基础语法: PIVOT 用于将列值旋转为列名(即行转列),在 SQL Server 2000可以用聚合函数配合CASE语句实现 PI ...

最新文章

  1. 正则表达式匹配单个字符(.、[]、\d、\D、\s、\S、\w、\W)
  2. 凸集+非凸集+凸函数+非凸函数
  3. 每日一皮:千万别和杠精一般见识...
  4. 介绍几种SSIS部署方式
  5. python模块批量安装方法_python离线批量安装依赖包
  6. 如何处理Android Studio 上面关于 update 和 commit 小箭头的消失
  7. 所有受限制的应用程序包_【译】使用Blazor构建桌面应用
  8. 美团数据仓库-数据脱敏
  9. 基于竞争的MAC协议
  10. 从三个方面理解ARM嵌入式系统
  11. linux xp双系统引导修复工具,XP和Linux双系统启动菜单的修复
  12. NPN型三极管基础知识解析
  13. [每日一氵] linux 批量删除某个名字的文件夹
  14. mac用brew安装mysql报错1045(28000)
  15. BZOJ2827: 千山鸟飞绝
  16. 墨画子卿第一章第4节:世界观的颠覆
  17. org.apache.kafka.clients.consumer.CommitFailedException
  18. 风险偏好情绪有所改善,非美低位反弹
  19. 大数据开发复习Spark篇
  20. 图像检测:图像预处理

热门文章

  1. qq动态页面变方格_腾讯QQ音乐9.7.5正式版更新:「歌手主页个人主页」界面全新改版...
  2. 向量封包处理器(VPP)如何运作
  3. lsof 命令实用用法介绍
  4. plsql怎么用字段查表明_PLSQL查询语句
  5. 计算机编程英语怎么写,计算机编程英语词汇大全.pdf
  6. java api 第一个类是_JAVA之Object常用API
  7. Netty实现长连接简单例子
  8. java可以继承私有的,关于java:继承中的私有方法
  9. 虚拟现实设备排行榜(2016年3月27日)
  10. 量子计算机有哪些战略意义,世界性颠覆!量子计算机在中国诞生,对我国有五层重大战略意义!...