科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网安全频道讲解数据库中行级转换成列级的实际应用

讲解数据库中行级转换成列级的实际应用

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本文将为大家讲解数据库中行级转换成列级的实际应用。

作者:赛迪网 袁小溪 来源:天新网 2008年4月14日

关键字: Mssql SQL SQL Server 数据库

  • 评论
  • 分享微博
  • 分享邮件

    讲解数据库中行级转换成列级的实际应用:

  首先,我们需要建立一个表,详细内容请参考下文:  

create table score
(
   Name    varchar(10),
   Subject varchar(10),
   Result int
)
go
 
-- Insert some data to score table
insert into score(Name , Subject , Result) values("Jason" , "Chinese" , 74)
insert into score(Name , Subject , Result) values("Jason" , "Math" , 83)
insert into score(Name , Subject , Result) values("Jason" , "Physic" , 93)
insert into score(Name , Subject , Result) values("Bosco" , "Chinese" , 74)
insert into score(Name , Subject , Result) values("Bosco" , "Math" , 84)
insert into score(Name , Subject , Result) values("Bosco" , "Physic" , 94)
go
 
-- useing PIVOT operator
SELECT * FROM
(    
    select Name,Subject,Result from score
) as X
PIVOT
(    
   Sum(Result) FOR Subject IN ([Chinese],[Math],[Physic])
) AS PVT
 
-- useing static SQL. There only are [Chinese],
[Math],[Physic] values in subject field
select Name,
 sum(case Subject when "Chinese" then Result else 0 end) as [Chinese],
 sum(case Subject when "Math" then Result else 0 end) as [Math],
 sum(case Subject when "Physic" then Result else 0 end) as [Physic]
from score
group by Name
 
-- useing dynamic SQL. There may be some other 
values in subject field,don"t limited to [Chinese],[Math],[Physic]
declare @sql varchar(2000)
set @sql = "select Name"
select @sql = @sql + ", sum(case Subject when 
""" + Subject + """ then Result else 0 end) [" + Subject + "]"
from (select distinct Subject from score) as X
set @sql = @sql + " from score group by Name"
exec(@sql)
    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章