SQL SERVER 2008的转置函数PIVOT

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介: PIVOT函数用于转置数据,即用旋转表的方式把行换成列。PIVOT可以将表中的列换成行 如下面的例子: CREATE TABLE Sales.SalesByMonth ( year char(4), month char(3), amount MONEY, ...

PIVOT函数用于转置数据,即用旋转表的方式把行换成列。PIVOT可以将表中的列换成行

如下面的例子:

CREATE TABLE Sales.SalesByMonth
(
    year char(4),
    month char(3),
    amount MONEY,
    PRIMARY KEY(year,month)
)

INSERT INTO Sales.SalesByMonth(year,month,amount)
values('2007','Jan',789.0000),
      ('2007','Feb',389.0000),
      ('2007','Mar',8867.0000),
      ('2007','Apr',778.0000),
      ('2007','May',78.0000),
      ('2007','Jun',9.0000),
      ('2007','Jul',987.0000),
      ('2007','Aug',866.0000),
      ('2007','Sep',7787.0000),
      ('2007','Oct',85576.0000),
      ('2007','Nov',855.0000),
      ('2007','Dec',5875.0000),
      
      ('2008','Jan',7.0000),
      ('2008','Feb',6868.0000),
      ('2008','Mar',688.0000),
      ('2008','Apr',9897.0000)
      
SELECT YEAR,
       SUM(case when month='Jan' then amount else 0 end) as 'Jan',
       SUM(case when month='Feb' then amount else 0 end) as 'Feb',
       SUM(case when month='Mar' then amount else 0 end) as 'Mar',
       SUM(case when month='Apr' then amount else 0 end) as 'Apr',
       SUM(case when month='May' then amount else 0 end) as 'May',
       SUM(case when month='Jun' then amount else 0 end) as 'Jun',
       SUM(case when month='Jul' then amount else 0 end) as 'Jul',
       SUM(case when month='Aug' then amount else 0 end) as 'Aug',
       SUM(case when month='Sep' then amount else 0 end) as 'Sep',
       SUM(case when month='Oct' then amount else 0 end) as 'Oct',
       SUM(case when month='Nov' then amount else 0 end) as 'Nov',
       SUM(case when month='Dec' then amount else 0 end) as 'Dec'
FROM Sales.SalesByMonth 
group by year     

select YEAR,[Jan],[Feb],[Mar],[Apr],[May],[Jun],
            [Jul],[Aug],[Sep],[Oct],[Nov],[Dec]
FROM 
    (Select YEAR,amount,month from Sales.SalesByMonth) as SalesByMonth 
    pivot (sum(amount) for month in 
            (
                [Jan],[Feb],[Mar],[Apr],[May],[Jun],
                [Jul],[Aug],[Sep],[Oct],[Nov],[Dec]
            )) as ourPivot
order by year

显示结果为:

如果去掉year选项,语句改为:

select [Jan],[Feb],[Mar],[Apr],[May],[Jun],
            [Jul],[Aug],[Sep],[Oct],[Nov],[Dec]
FROM 
    (Select amount,month from Sales.SalesByMonth) as SalesByMonth 
    pivot (sum(amount) for month in 
            (
                [Jan],[Feb],[Mar],[Apr],[May],[Jun],
                [Jul],[Aug],[Sep],[Oct],[Nov],[Dec]
            )) as ourPivot

则显示结果:

 

 

 

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
2月前
|
SQL Oracle 关系型数据库
SQL优化-使用联合索引和函数索引
在一次例行巡检中,发现一条使用 `to_char` 函数将日期转换为字符串的 SQL 语句 CPU 利用率很高。为了优化该语句,首先分析了 where 条件中各列的选择性,并创建了不同类型的索引,包括普通索引、函数索引和虚拟列索引。通过对比不同索引的执行计划,最终确定了使用复合索引(包含函数表达式)能够显著降低查询成本,提高执行效率。
|
2月前
|
SQL 数据库 数据库管理
数据库SQL函数应用技巧与方法
在数据库管理中,SQL函数是处理和分析数据的强大工具
|
2月前
|
SQL 数据库 索引
SQL中COUNT函数结合条件使用的技巧与方法
在SQL查询中,COUNT函数是一个非常常用的聚合函数,用于计算表中满足特定条件的记录数
|
2月前
|
SQL 关系型数据库 MySQL
SQL日期函数
SQL日期函数
|
3月前
|
SQL 关系型数据库 C语言
PostgreSQL SQL扩展 ---- C语言函数(三)
可以用C(或者与C兼容,比如C++)语言编写用户自定义函数(User-defined functions)。这些函数被编译到动态可加载目标文件(也称为共享库)中并被守护进程加载到服务中。“C语言函数”与“内部函数”的区别就在于动态加载这个特性,二者的实际编码约定本质上是相同的(因此,标准的内部函数库为用户自定义C语言函数提供了丰富的示例代码)
|
3月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
4月前
|
SQL 数据处理 数据库
|
4月前
|
SQL Oracle 关系型数据库
SQL 中的大小写处理函数详解
【8月更文挑战第31天】
185 0
|
4月前
|
SQL 数据采集 数据挖掘
为什么要使用 SQL 函数?详尽分析
【8月更文挑战第31天】
62 0
|
4月前
|
SQL 存储 关系型数据库
COALESCE 函数:SQL中的空值处理利器
【8月更文挑战第31天】
672 0
下一篇
DataWorks