create table tb(姓名 varchar(10) , ?程 varchar(10) , 分? int)
insert into tb values('?三' , '?文' , 74)
insert into tb values('?三' , '??' , 83)
insert into tb values('?三' , '物理' , 93)
insert into tb values('李四' , '?文' , 74)
insert into tb values('李四' , '??' , 84)
insert into tb values('李四' , '物理' , 94)
go
--SQL SERVER 2000 ??SQL,指?程只有?文、??、物理?三??程。(以下同)
select 姓名 as 姓名 ,
max(case ?程 when '?文' then 分? else 0 end) ?文,
max(case ?程 when '??' then 分? else 0 end) ??,
max(case ?程 when '物理' then 分? else 0 end) 物理
from tb
group by 姓名
--SQL SERVER 2000 ??SQL,指?程不止?文、??、物理?三??程。(以下同)
declare @sql varchar(8000)
set @sql = 'select 姓名 '
select @sql = @sql + ' , max(case ?程 when ''' + ?程 + ''' then 分? else 0 end) [' + ?程 + ']'
from (select distinct ?程 from tb) as a
set @sql = @sql + ' from tb group by 姓名'
exec(@sql)
--SQL SERVER 2005 ??SQL。
select * from (select * from tb) a pivot (max(分?) for ?程 in (?文,??,物理)) b
--SQL SERVER 2005 ??SQL。
declare @sql varchar(8000)
select @sql = isnull(@sql + '],[' , '') + ?程 from tb group by ?程
set @sql = '[' + @sql + ']'
exec ('select * from (select * from tb) a pivot (max(分?) for ?程 in (' + @sql + ')) b')
--SQL SERVER 2000 ??SQL。
---------------------------------------------------------------------------------------------------------
select 姓名 姓名,
max(case ?程 when '?文' then 分? else 0 end) ?文,
max(case ?程 when '??' then 分? else 0 end) ??,
max(case ?程 when '物理' then 分? else 0 end) 物理,
cast(avg(分?*1.0) as decimal(18,2)) 平均分,
sum(分?) ?分
from tb
group by 姓名
--SQL SERVER 2000 ??SQL。
declare @sql varchar(8000)
set @sql = 'select 姓名 '
select @sql = @sql + ' , max(case ?程 when ''' + ?程 + ''' then 分? else 0 end) [' + ?程 + ']'
from (select distinct ?程 from tb) as a
set @sql = @sql + ' , cast(avg(分?*1.0) as decimal(18,2)) 平均分 , sum(分?) ?分 from tb group by 姓名'
exec(@sql)
--SQL SERVER 2005 ??SQL。
select m.* , n.平均分 , n.?分 from
(select * from (select * from tb) a pivot (max(分?) for ?程 in (?文,??,物理)) b) m,
(select 姓名 , cast(avg(分?*1.0) as decimal(18,2)) 平均分 , sum(分?) ?分 from tb group by 姓名) n
where m.姓名 = n.姓名
--SQL SERVER 2005 ??SQL。
declare @sql varchar(8000)
select @sql = isnull(@sql + ',' , '') + ?程 from tb group by ?程
exec ('select m.* , n.平均分 , n.?分 from
(select * from (select * from tb) a pivot (max(分?) for ?程 in (' + @sql + ')) b) m ,
(select 姓名 , cast(avg(分?*1.0) as decimal(18,2)) 平均分 , sum(分?) ?分 from tb group by 姓名) n
where m.姓名 = n.姓名')
create table tb(姓名 varchar(10) , ?文 int , ?? int , 物理 int)
insert into tb values('?三',74,83,93)
insert into tb values('李四',74,84,94)
go
--SQL SERVER 2000 ??SQL。
select * from
(
select 姓名 , ?程 = '?文' , 分? = ?文 from tb
union all
select 姓名 , ?程 = '??' , 分? = ?? from tb
union all
select 姓名 , ?程 = '物理' , 分? = 物理 from tb
) t
order by 姓名 , case ?程 when '?文' then 1 when '??' then 2 when '物理' then 3 end
--SQL SERVER 2000 ??SQL。
--?用系?表??生?。
declare @sql varchar(8000)
select @sql = isnull(@sql + ' union all ' , '' ) + ' select 姓名 , [?程] = ' + quotename(Name , '''') + ' , [分?] = ' + quotename(Name) + ' from tb'
from syscolumns
where name! = N'姓名' and ID = object_id('tb') --表名tb,不包含列名?姓名的其它列
order by colid asc
exec(@sql + ' order by 姓名 ')
--SQL SERVER 2005 ??SQL。
select 姓名 , ?程 , 分? from tb unpivot (分? for ?程 in([?文] , [??] , [物理])) t
select * from
(
select 姓名 as 姓名 , ?程 = '?文' , 分? = ?文 from tb
union all
select 姓名 as 姓名 , ?程 = '??' , 分? = ?? from tb
union all
select 姓名 as 姓名 , ?程 = '物理' , 分? = 物理 from tb
union all
select 姓名 as 姓名 , ?程 = '平均分' , 分? = cast((?文 + ?? + 物理)*1.0/3 as decimal(18,2)) from tb
union all
select 姓名 as 姓名 , ?程 = '?分' , 分? = ?文 + ?? + 物理 from tb
) t
order by 姓名 , case ?程 when '?文' then 1 when '??' then 2 when '物理' then 3 when '平均分' then 4 when '?分' then 5 end