读书人

高级行变列有关问题

发布时间: 2012-04-12 15:46:35 作者: rapoo

高级行变列问题
现有一张表如下
khjl qd pq rq num
张三 北京总部 华北地区 1995 4
李四 深圳总部 华南地区 1996 153
王五 上海总部 华东地区 1997 246


现在想要的结果为:

khjl qd pq 1995 1996 1997
张三 北京总部 华北地区 4 0 0
李四 深圳总部 华南地区 0 153 0
王五 上海总部 华东地区 0 0 246

请高手帮忙解答!


[解决办法]

SQL code
--> 测试数据:[tbl]if object_id('[tbl]') is not null drop table [tbl]create table [tbl]([khjl] varchar(4),[qd] varchar(8),[pq] varchar(8),[rq] int,[num] int)insert [tbl]select '张三','北京总部','华北地区',1995,4 union allselect '李四','深圳总部','华南地区',1996,153 union allselect '王五','上海总部','华东地区',1997,246godeclare @str varchar(max)set @str=''select @str=@str+','+'['+ltrim([rq])+']'+'=max(case when [rq]='+QUOTENAME([rq],'''')+' then [num] else 0 end)' from tbl group by [rq]exec('select [khjl],[qd],[pq]'+@str+' from tbl group by [khjl],[qd],[pq]')/*khjl    qd    pq    1995    1996    1997李四    深圳总部    华南地区    0    153    0王五    上海总部    华东地区    0    0    246张三    北京总部    华北地区    4    0    0*/ 

读书人网 >SQL Server

热点推荐