日期:2014-05-17  浏览次数:20559 次

求SQL语句,行转列并进行汇总
大家好!
  如何将一个表中的行转行列并进行汇总。详情见下图:

既将A表的数据转成B表,其中A表的数据行数不固定。

------解决方案--------------------
又见行转列呀
DROP TABLE #tb
create table #tb([品号] int,[日期] varchar(5),[数量] int)
insert #tb
select 1001,'06-08',11 union all
select 1001,'06-09',12 union all
select 1001,'06-10',13 union all
select 1001,'06-11',14 union all
select 1001,'06-12',15

DECLARE @sql NVARCHAR(MAX), @colList NVARCHAR(MAX)
SET @colList = STUFF((SELECT ','+QUOTENAME([日期]) FROM #tb GROUP BY [日期] ORDER BY [日期] FOR XML PATH('')),1,1,'')
SET @sql = N'
    select * from #tb a
    pivot
    (max([数量]) for [日期] in('+ @colList +')) b
'
EXEC(@sql)
/*
品号 06-08 06-09 06-10 06-11 06-12
1001 11 12 13 14 15
*/

------解决方案--------------------
我这里哪里指定列了?我特意写的是动态的,难道你没试过?
引用:
Quote: 引用:

----------------------------
-- Author  :DBA_Huangzj(發糞塗牆)
-- Date    :2013-08-09 14:40:54
-- Version:
--      Microsoft SQL Server 2014 (CTP1) - 11.0.9120.5 (X64) 
-- Jun 10 2013 20:09:10 
-- Copyright (c) Microsoft Corporation
-- Enterprise Evaluation Edition (64-bit) on Windows NT 6.2 <X64> (Build 9200: ) (Hypervisor)
--
----------------------------
--> 测试数据:[A]
if object_id('[A]') is not null drop table [A]
go 
create table [A]([品号] int,[日期] varchar(5),[数量] int)
insert [A]
select 1001,'06-08',11 union all
select 1001,'06-09',12 union all
select 1001,'06-10',13 union all
select 1001,'06-11',14 union all
select 1001,'06-12',15
--------------开始查询--------------------------

declare @s nvarchar(4000)
set @s=''
Select     @s=@s+','+quotename([日期])+'=max(case when [日期]='+quotename([日期],'''')+' then [数量] else 0 end)'
from [A] group by [日期]
exec('select [品号]'+@s+' from A group by [品号]')
----------------结果----------------------------
/* 
品号          06-08       06-09       06-10       06-11       06-12
----------- ----------- ----------- ----------- ----------- -----------
1001        11  &