华少.Net

Do my best to taste the next chocolate

  :: :: 新随笔 :: 联系 :: 订阅 :: 管理 ::

 Create table test (name char(10),km char(10),cj int)
go
insert test values('张三','语文',80)
insert test values('张三','数学',86)
insert test values('张三','英语',75)
insert test values('李四','语文',78)
insert test values('李四','数学',85)
insert test values('李四','英语',78)
/*
想变成

姓名   语文   数学   英语
张三   80     86     75
李四   78     85     78
*/

declare @sql varchar(8000)
set @sql = 'select name'
select @sql = @sql + ',sum(case km when '''+km+''' then cj end) ['+km+']'
 from (select distinct km from test) as a
select @sql = @sql+' from test group by name'
exec(@sql)

drop table test

posted on 2005-12-02 13:56  郑卫华  阅读(60)  评论(0)    收藏  举报