[转]SQL 2005中pivot and unpivot的用法

简介:
 .Pivot 的用法体会
语句范例
select PN,[2006/5/30] as [20060530],[2006/6/2] as [20060602]  
from consumptiondata a 
Pivot (sum(a.M_qty) FOR a.M_date in ([2006/5/30],[2006/6/2])) as PVT  
order by PN 
  
Table 结构  Consumptiondata (PN,M_Date,M_qty) 
order by PN 可要可不要 , 并不重要 , 只是排序的作用  
  
关键的是红色部分 , 解析如下 ,select  大家都知道 ,PN  ConsumptionData 表中的一个 Column, 
[2006/5/30] 也是一个 Column, 他需要显示成 [20060530], 注意 [2006/5/30] 不是一个 Value, 而是一个 Column.[2006/6/2] [2006/5/30] 一样
Pivot ( ........... ) as PVT 这个结构是固定格式 , 没有什么需要特殊说明的 , 当然 PVT 随便你给他一个  NICKNAME ,it doesn't make any differences.  
sum(a.M_qty)   是我们希望显示出来的值 , 注意这个地方必须用汇总函数 , 否则语法不会过
FOR a.M_date in ([2006/5/30],[2006/6/2]) for  表示汇总的值要显示在哪一个 Column 下面  
如果我们想让 Sum(M_qty) 显示在 PN 转换的 Column 下面 , 则可写为 For PN, in  的清单表示我们关注哪些要查看的 Column, 注意再次强调是 Column, 不是 Value. in 的清单是 Column 清单 , 不是 Value 清单 , M_date Value 转换成的 Column 清单
  
2.UnPivot 
-- 此段可以直接在 Sql 2005 中执行  
CREATE TABLE pvt (VendorID int, Emp1 int, Emp2 int,
Emp3 int, Emp4 int, Emp5 int)
GO
INSERT INTO pvt VALUES (1,4,3,5,4,4)
INSERT INTO pvt VALUES (2,4,1,5,5,5)
INSERT INTO pvt VALUES (3,4,3,5,4,4)
INSERT INTO pvt VALUES (4,4,2,5,5,4)
INSERT INTO pvt VALUES (5,5,1,5,5,5)
GO 
--select * from PVT 
--Unpivot the table.
SELECT VendorID, Employee, Orders 
FROM PVT
UNPIVOT ( 
 Orders FOR Employee IN ([Emp1], [Emp2], [Emp3], [Emp4], [Emp5])
)AS unpvt 
GO 
  
说明 : Employee  Column [Emp1]... 为值 , Orders Column [Emp1]... 的值为值
目录
相关文章
|
6月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】共享利用Python脚本解决Oracle的SQL脚本@@用法
【YashanDB知识库】共享利用Python脚本解决Oracle的SQL脚本@@用法
|
6月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】共享利用Python脚本解决Oracle的SQL脚本@@用法
本文来自YashanDB官网,介绍如何处理Oracle客户端sql*plus中使用@@调用同级目录SQL脚本的场景。崖山数据库23.2.x.100已支持@@用法,但旧版本可通过Python脚本批量重写SQL文件,将@@替换为绝对路径。文章通过Oracle示例展示了具体用法,并提供Python脚本实现自动化处理,最后调整批处理脚本以适配YashanDB运行环境。
|
SQL Java 数据库连接
SQL SELECT语句的基本用法
SQL SELECT语句的基本用法
|
SQL 程序员
sql中的distinct用法
`DISTINCT`在SQL中用于返回唯一不同的值,消除结果集中的重复行。基本用法包括:1) 选择单列唯一值,如`SELECT DISTINCT department FROM employees;`
mybatis复习03,动态SQL,if,choose,where,set,trim标签及foreach标签的用法
文章介绍了MyBatis中动态SQL的用法,包括if、choose、where、set和trim标签,以及foreach标签的详细使用。通过实际代码示例,展示了如何根据条件动态构建查询、更新和批量插入操作的SQL语句。
mybatis复习03,动态SQL,if,choose,where,set,trim标签及foreach标签的用法
|
SQL 存储 安全
SQL Server用法
SQL Server用法
277 1
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
193 1
|
SQL 关系型数据库 MySQL
8、SQL高级用法
8、SQL高级用法
77 0
|
SQL 数据库
SQL中CASE WHEN THEN ELSE END的用法详解
SQL中CASE WHEN THEN ELSE END的用法详解
2503 2
|
SQL 数据库
SQL DISTINCT 用法总结
SQL DISTINCT 用法总结
4540 3