首页 > 数据库技术 > 详细

PCB MS SQL 行转列(动态拼SQL)

时间:2018-06-30 20:43:42      阅读:206      评论:0      收藏:0      [点我收藏+]

 一.原数据:

SELECT inman,indate
FROM [fp_db].[dbo].[ppezhpbb]
WHERE indate > 2016-5-1 AND indate < 2016-6-1
ORDER BY indate

技术分享图片

 

二.转换后(动态拼接SQL):

--数据先存临时表
SELECT  inman,indate INTO #tab
FROM [fp_db].[dbo].[ppezhpbb]
WHERE indate > 2016-5-1 AND indate < 2016-6-1
--拼接字符串
DECLARE @sql NVARCHAR(MAX)
SET @sql = SELECT CONVERT(varchar(100), indate, 23) indate  
SELECT @sql = @sql +  ,sum(case when inman=‘‘‘ + inman + ‘‘‘ then 1 else 0 end)  + inman  --行转列统计
FROM #tab
GROUP BY inman   --需由列转行的字段
SET @sql = @sql +  FROM [fp_db].[dbo].[ppezhpbb] WHERE indate > ‘‘2016-5-1‘‘ AND indate < ‘‘2016-6-1‘‘ 
SET @sql = @sql +  GROUP BY CONVERT(varchar(100), indate, 23) 
SET @sql = @sql +  ORDER BY indate 
SELECT @sql
exec sp_executesql @sql

技术分享图片

 

PCB MS SQL 行转列(动态拼SQL)

原文:https://www.cnblogs.com/pcbren/p/9248521.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!