==========行转列(PIVOT函数求解)=========
时间:2011-12-03
来源:互联网
近日在处理行转列时遇到困惑,特向C友们求解。
测试数据如下:
SQL code
测试数据如下:
SQL code
CREATE TABLE A ( uid INT, pname CHAR(4), pcount INT, pmoney INT ) CREATE TABLE B ( deptID INT, groupID INT, uid int ) INSERT a SELECT 1,'A',1,2 UNION ALL SELECT 2,'B',1,4 UNION ALL SELECT 3,'A',1,2 UNION ALL SELECT 1,'A',1,2 UNION ALL SELECT 1,'A',1,2 UNION ALL SELECT 2,'A',1,2 UNION ALL SELECT 3,'B',1,4 UNION ALL SELECT 1,'A',1,2 UNION ALL SELECT 1,'A',1,2 INSERT b SELECT 1,1,1 UNION ALL SELECT 1,1,2 UNION ALL SELECT 1,2,3 结果要求: deptid groupid uid A A _count B B _count ----------- ----------- ----------- ----------- ----------- ----------- ----------- 1 1 1 10 5 0 0 1 1 2 2 1 4 1 1 2 3 2 1 4 1 解决方案: DECLARE @sql NVARCHAR(MAX) SELECT @sql=ISNULL(@sql+',','')+QUOTENAME(pname)+'=sum(case when pname=N'+QUOTENAME(pname,'''')+' then pmoney else 0 end),'+QUOTENAME(pname+'_count')+'=sum(case when pname=N'+QUOTENAME(pname,'''')+' then pcount else 0 end)' FROM a GROUP BY pname SET @sql='select b.deptid,b.groupid,t.* from b left join(select uid,'+@sql+' from a group by uid) t on t.uid=b.uid' EXEC(@sql) 问题: PIVOT能否实现?如何采用PIVOT实现?
作者: wing7742 发布时间: 2011-12-03
PIVOT 也需要动态拼SQL字符串
作者: pengxuan 发布时间: 2011-12-03
要用pivot ,先得整理成可以供它用的形式.
作者: qianjin036a 发布时间: 2011-12-03
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28