PIVOT | UNPIVOT_1
Pivot应用
/*
《Microsoft SQL Server 2008 T-SQL Fundamentals (PRO-Developer)》
《Microsoft SQL Server 2012 T-SQL Fundamentals》
*/ if object_id('dbo.orders','U') is not null drop table dbo.orders;
GO
CREATE TABLE dbo.Orders
(
orderid INT NOT NULL,
orderdate DATE NOT NULL,
empid INT NOT NULL,
custid VARCHAR(5) NOT NULL,
qty INT NOT NULL,
CONSTRAINT PK_Orders PRIMARY KEY(orderid)
);
GO
INSERT INTO dbo.Orders(orderid, orderdate, empid, custid, qty)
VALUES
(30001, '', 3, 'A', 10),
(10001, '', 2, 'A', 12),
(10005, '', 1, 'B', 20),
(40001, '', 2, 'A', 40),
(10006, '', 1, 'C', 14),
(20001, '', 2, 'B', 12),
(40005, '', 3, 'A', 10),
(20002, '', 1, 'C', 20),
(30003, '', 2, 'B', 15),
(30004, '', 3, 'C', 22),
(30007, '', 3, 'D', 30); select * from orders select empid,custid,sum(qty) as SumQty
from dbo.Orders
group by empid,custid
-----------------------------------------------------------------
--
select empid,
sum(case when custid='A' then qty end) as A,
sum(case when custid='B' then qty end) as B,
sum(case when custid='C' then qty end) as C,
sum(case when custid='D' then qty end) as D from dbo.Orders
group by empid
-----------------------------------------------------------------
--
SELECT empid --,orderid,orderdate,
SUM(CASE WHEN custid = 'A' THEN qty END) AS A,
SUM(CASE WHEN custid = 'B' THEN qty END) AS B,
SUM(CASE WHEN custid = 'C' THEN qty END) AS C,
SUM(CASE WHEN custid = 'D' THEN qty END) AS D
FROM dbo.Orders
GROUP BY orderid, orderdate, empid;
-----------------------------------------------------------------
--3 使用PIVOT操作符转置
--PIVOT语法(此处还是将语法摆在此处,以形成一个理论形式):
select ...
from (SourceTable or TableExpression)
pivot (<agg_func>(<aggregation_element>)) for <spreading_element> in (<list_of_targe_columns>) as <result_table_alias> select empid, A, B, C, D
from (select empid,custid,qty
from dbo.orders) as D
PIVOT(SUM(qty) for custid in(A,B,C,D)) as p
-----------------------------------------------------------------
--
SELECT empid, A, B, C, D
FROM dbo.Orders
PIVOT(SUM(qty) FOR custid IN(A, B, C, D)) AS P;
-----------------------------------------------------------------
--
SELECT custid, [], [], []
FROM (SELECT empid, custid, qty
FROM dbo.Orders) AS D
PIVOT(SUM(qty) FOR empid IN([], [], [])) AS P;
----------------------------------------------------------------- -----------------------------------------------------------------
I strongly recommend that you never operate on the base table directly, even when the table contains only columns used as pivoting elements.
You never know whether new columns will be added to the table in the future, rendering your queries incorrect.
I recommend considering the use of a table expression as the input table to the PIVOT operator as if it were part of the requirement of the operator's syntax.
--1 -3 --5

--2 --4

_____________上面是PIVOT的训练------------------------
--------------------下面是UNPIVOT的训练,与PIVOT放在一起便于对比理解--------------------
----------UNPIVOT的应用 (Jun 3,增补)
--就将PIVOT的结果集,当做UNPIVOT训练的源表,由此可产生出一个新表来以作为我们的“源”训练
--我们要做的其实就是将 PIVOT的结果集旋转过来 if object_id('EmpCustOrders','U') is not null drop EmpCustOrders;
select empid,A,B,C,D
into EmpCustOrders
from (select empid,custid,qty
from Orders) as F
PIVOT (sum(qty) for custid in(A,B,C,D)) as p; select * from EmpCustOrders ----------EmpCustOrders,现在就是我们操作的对象了
-----------------------------------------------------------------
--第1步
--1 (MSSQL2008, we can use a table value constructor in the form of values clause)
select *
from EmpCustOrders
cross join (values('A'),('B'),('C'),('D')) AS Custs(custid);
----------
--1.1 (before MSSQL2008, we need substitute the values clauses withe a series of select statements)
select *
from EmpCustOrders
cross join (select 'A' as custid
union all select 'B'
union all select 'C'
union all select 'D') as CustsABC;
-----------------------------------------------------------------
--第2步
--
select empid,custid,
CASE custid
when 'A' then A
when 'B' then B
when 'C' then C
when 'D' then D
END AS qty
from EmpCustOrders
cross join (values('A'),('B'),('C'),('D')) AS Custs(custid)
--第3步(在第2步的基础上,去除那些 null 的数据),此步骤已经实现了旋转后的结果
--
select *
from(
select empid,custid,
CASE custid
when 'A' then A
when 'B' then B
when 'C' then C
when 'D' then D
END AS qty
from EmpCustOrders
cross join (values('A'),('B'),('C'),('D')) AS Custs(custid)
) as p
where qty is not null; --既然学习UNPIVOT,就用此法实现
--UNPIVOT语法
-PIVOT语法(此处还是将语法摆在此处,以形成一个理论形式):
--3.1
select ...
from (SourceTable or TableExpression)
unpivot <target_col_to_hold_source_col_values> --->>>unpivot里面的参数不要进行聚合计算
for <target_col_to_hold_source_col_names> in (<list_of_source_columns>) as <result_table_alias> -- select empid,custid,qty
from EmpCustOrders
unpivot(qty for custid in(A,B,C,D)) as p; --
-- 我们将 PIVOT的结果集( 参考PIVOT的运行结果 --5),生成了一个新表,
--select * from EmpCustOrders
--1 --2 --3 --3.1(UNPIVOT方式)

PIVOT | UNPIVOT_1的更多相关文章
- Pivot 和 Unpivot
在TSQL中,使用Pivot和Unpivot运算符将一个关系表转换成另外一个关系表,两个命令实现的操作是“相反”的,但是,pivot之后,不能通过unpivot将数据还原.这两个运算符的操作数比较复杂 ...
- SQL Server中行列转换 Pivot UnPivot
SQL Server中行列转换 Pivot UnPivot PIVOT用于将列值旋转为列名(即行转列),在SQL Server 2000可以用聚合函数配合CASE语句实现 PIVOT的一般语法是:PI ...
- Open xml 操作Excel 透视表(Pivot table)-- 实现Excel多语言报表
我的一个ERP项目中,客户希望使用Excel Pivot table 做分析报表. ERP 从数据库中读出数据,导出到Excel中的数据源表(统一命名为Data),刷新Pivot table! 客户还 ...
- SQL(横表和纵表)行列转换,PIVOT与UNPIVOT的区别和使用方法举例,合并列的例子
使用过SQL Server 2000的人都知道,要想实现行列转换,必须综合利用聚合函数和动态SQL,具体实现起来需要一定的技巧,而在SQL Server 2005中,使用新引进的关键字PIVOT/UN ...
- T-SQL Recipes之Dynamic PIVOT and UNPIVOT
PIVOT PIVOT在行转列的时候经常用到,最便捷的方式就是通过示例来理解它的作用. 示例1 Query to Return Select Product Data from AdventureWo ...
- sql的行转列(PIVOT)与列转行(UNPIVOT)
在做数据统计的时候,行转列,列转行是经常碰到的问题.case when方式太麻烦了,而且可扩展性不强,可以使用 PIVOT,UNPIVOT比较快速实现行转列,列转行,而且可扩展性强 一.行转列 1.测 ...
- Panorama和Pivot的区别
Panorama 1.提供了更丰富的用户体验(建议最多4个Items项) 2.Item可以设置屏幕方向为水平,支持多于一个屏幕的显示 3.可以使用任意大小的背景图片,Panorama会自动地缩放为屏幕 ...
- 如何用Pivot实现行列转换
在Oracle中,如果要实现行列转换,较为常见的是用DECODE和CASE语句.对于简单的行列转行,DECODE和CASE语句尚能应付.在逻辑比较复杂,分组聚合较多的场景中,DECODE和CASE语句 ...
- SQL Server SQL性能优化之--pivot行列转换减少扫描计数优化查询语句
原文出处:http://www.cnblogs.com/wy123/p/5933734.html 先看常用的一种表结构设计方式: 那么可能会遇到一种典型的查询方式,主子表关联,查询子表中的某些(或者全 ...
随机推荐
- JAVA基础4---序列化和反序列化深入整理(JDK序列化)
一.什么是序列化和反序列化? 序列化:将对象状态信息转化成可以存储或传输的形式的过程(Java中就是将对象转化成字节序列的过程) 反序列化:从存储文件中恢复对象的过程(Java中就是通过字节序列转化成 ...
- 09-Python之路---函数进阶
Python之路---函数进阶️ 程序员三大美德: 懒惰 因为一直致力于减少工作的总工作量. 缺乏耐性 因为一旦让你去做本该计算机完成的事,你将会怒不可遏. 傲慢 因为被荣誉感冲晕头的你会把程序写得让 ...
- Redis学习笔记(十四)Sentinel(哨兵)(上)
最近谈到Redis就会听到哨兵模式,工作期间同事也分享过关于哨兵模式的知识,但由于工作忙(给自己找个借口)没有没认真看,现在恶补下,老样子还是分上篇应用,下篇看实现过程,下面我们来看下哨兵到底是啥? ...
- UVA10779 Collectors Problem
题目链接:https://cn.vjudge.net/problem/UVA-10779 前言: 本题是关于姜志豪<网络流的一些建模方法>的笔记. 知识点: 最大流 题意摘抄: \(Bob ...
- Spring注入的对象到底是什么类型
开篇 之前,在用spring编码调试的时候,有时候发现被自动注入的对象是原始类的对象,有时候是代理类的对象,那什么时候注入的原始类对象呢,有什么时候注入的是代理类的对象呢?心里就留下了这个疑问.后来再 ...
- XXX_ProductCRUD的项目结构与配置文件
MVC_ProductCRUD Hibernate_ProductCRUD 项目结构 ...
- MongoDB快速入门指南与docker-compose快体验
MongoDB快速入门指南与docker-compose快体验 MongoDB相对于RDBMS的优势 模式少 -MongoDB是一个文档数据库,其中一个集合包含不同的文档.一个文档之间的字段数,内容和 ...
- python运用 - log信息提取(知识: 遍历 | os )
运用到的python知识点: excel相关:https://www.cnblogs.com/yaner2018/p/11269873.html 字典: python字典的几种方式: 1)key值遍历 ...
- [01]HTML基础之简单介绍
1.前言 现如今科技进步,足不出户尽晓天下事,一转身便仿若隔世茫然.科技绽放时代,网络技术对人们的触变无疑是深远而重大的,隐于缤纷绚丽的网页背后,是前端的蜕变更新. 如今,随意点开页面,绚丽华彩的特效 ...
- Magicodes.IE 在100万数据量下导入导出性能测试
原文作者:HueiFeng 前言 目前Magicodes.IE更新到了2.2.3,感谢大家的支持,同时建议大家在使用过程中如果遇到一些问题或者说需要一些额外的功能可以直接提issues,当然更建议大家 ...