Sqlserver中PIVOT行转列透视操作
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Sqlserver中PIVOT行转列透视操作,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1574字,纯文字阅读大概需要3分钟。
内容图文
![Sqlserver中PIVOT行转列透视操作](/upload/InfoBanner/zyjiaocheng/477/07d1eb3ac920454dba5caa02b13c4070.jpg)
创建表:
IF OBJECT_ID(‘T040_PRODUCT_SALES‘) IS NOT NULL DROP TABLE T040_PRODUCT_SALES create table T040_PRODUCT_SALES ( ID INT IDENTITY(1,1), ProductName VARCHAR(20), SaleMonth INT, SalesCount INT )
插入数据并排序:
INSERT INTO T040_PRODUCT_SALES VALUES (‘Bicycle‘,1,1), (‘Shoes‘,2,2), (‘Clothes‘,3,3), (‘Books‘,4,4), (‘Medicine‘,5,5), (‘Drinks‘,6,6), (‘Shoes‘,7,7), (‘Books‘,1,2), (‘Bicycle‘,1,3), (‘Medicine‘,1,4), (‘Clothes‘,1,5), (‘Mobile Phone‘,1,6), (‘Books‘,1,7), (‘Medicine‘,1,8), (‘Shoes‘,1,9), (‘Bicycle‘,2,10) SELECT ProductName, SaleMonth, SUM(SalesCount) AS SalesCount FROM T040_PRODUCT_SALES GROUP BY ProductName, SaleMonth ORDER BY ProductName, SaleMonth
格式:
/**** SELECT 非透视列, [透视列 1] AS ‘列名1‘, [透视列 2] AS ‘列名2‘, [透视列 3] AS ‘列名3‘ FROM ( -- 源数据 SELECT 非透视列, 透视列值的来源列, 需要聚合的值 FROM 表 )AS 别名 PIVOT ( SUM(需要聚合的值) FOR 透视列值的来源列 IN ([透视列 1],[透视列 2],[透视列 3]) )AS 别名 ****/
行转列的代码:
select ProductName, ISNULL([1],0) AS ‘1‘, ISNULL([2],0) AS ‘2‘, ISNULL([3],0) AS ‘3‘, ISNULL([4],0) AS ‘4‘, ISNULL([5],0) AS ‘5‘, ISNULL([6],0) AS ‘6‘ from ( select ProductName, SaleMonth, SalesCount from T040_PRODUCT_SALES) as Sales pivot ( SUM(SalesCount) FOR SaleMonth IN([1],[2],[3],[4],[5],[6]) ) as PIVOTBL
结果:
Sqlserver中PIVOT行转列透视操作
标签:arch values esc 代码 来源 entity ges int 建表
本文系统来源:http://www.cnblogs.com/sunliyuan/p/6595977.html
内容总结
以上是互联网集市为您收集整理的Sqlserver中PIVOT行转列透视操作全部内容,希望文章能够帮你解决Sqlserver中PIVOT行转列透视操作所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。