首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > SQL Server >

求SQL话语,行转列并进行汇总

2013-09-28 
求SQL语句,行转列并进行汇总大家好!如何将一个表中的行转行列并进行汇总。详情见下图:既将A表的数据转成B表

求SQL语句,行转列并进行汇总
大家好!
  如何将一个表中的行转行列并进行汇总。详情见下图:
求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-0806-0906-1006-1106-12
10011112131415
*/

[解决办法]
我这里哪里指定列了?我特意写的是动态的,难道你没试过?
引用:
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          12          13          14          15
*/
这对固定列的表可以用这种方法,但我的需求是列是不固定的。

热点排行