sql server行转列问题终极解决

2016-01-29 15:53 57 1 收藏

sql server行转列问题终极解决,sql server行转列问题终极解决

【 tulaoshi.com - SQLServer 】

主要应用case语句来解决行转列的问题

行转列问题主要分为两类

1)简单的行转列问题:

示例表:

id  sid           course  result

1   2005001 语文     80.0
2   2005001 数学     90.0
3   2005001 英语     80.0
4   2005002 语文     56.0
5   2005002 数学     69.0
6   2005002 英语     89.0

执行

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/sqlserver/)

select sid,语文=isnull(sum(case course when '语文' then result end),0),
   数学=isnull(sum(case course when '数学' then result end),0),
   英语=isnull(sum(case course when '英语' then result end),0)
   from result
   group by sid
   order by sid

 

得出结果

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/sqlserver/)

sid           语文 数学 英语

2005001 80.0  90.0  80.0
2005002 56.0  69.0  89.0

 

2)较为复杂的行转列

表1:course

id name

1 语文
2 数学
3 英语


表2:result

id sid          course  result

1 2005001 语文      80.0
2 2005001 数学      90.0
3 2005001 英语      80.0
4 2005002 语文      56.0
5 2005002 数学      69.0
6 2005002 英语      89.0

 

declare @sql varchar(8000)
set @sql='select sid'
select @sql=@sql+','+course.name+'=isnull(sum(case course when '''+course.name+''' then result end),0)'
 from course order by id
set @sql=@sql+' from result group by sid order by sid'
print @sql
exec(@sql)

 

得出结果

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/sqlserver/)

sid           语文 数学 英语

2005001 80.0  90.0  80.0
2005002 56.0  69.0  89.0

http://blog.csdn.net/tthxqttzln/archive/2007/02/02/1500825.aspx

来源:http://www.tulaoshi.com/n/20160129/1496690.html

延伸阅读
标签: SQLServer
  SQL Server 2000 是当今网络编程中使用的比较多的一个数据库系统,java是目前最流行的编程语言,在编程中涉及的比较多也比较重要的就是数据库问题,java自身提供了对各类主流数据库系统的支持,通过java.sql 库,提供了统一的接口,使得可以在java环境下不必对程序作大规模的修改,只要更改相应的驱动程序,即可实现对各类数据库的...
正在看的ORACLE教程是:Microsoft SQL Server 安全问题。 Microsoft SQL Server 7.0安全问题 Microsoft Corporation SQL Server 7.0 有哪几种安全模式? 两种:SQL Server和Windows NT(混合)及Windows NT only。SQL Server 和Windows NT相当于SQL Server 6.5版本的混合模式。Windows NT only相当于SQL Server 6.5 版本的信任模式。在SQL...
曾经以为SQL SERVER的触发器只能触发单行,也就是说如果一个delete触发器,如果同时删除多行时,只会对第一条记录触发,后来发现了不是人家SQL SERVER不支持,而是偶脑子笨没发现。 其实inserted和deleted两张内部表存放了所有要插入或要删除的记录,可以用cursor逐次访问里面的每条记录,下面是一个示例,该触发器将要删除的记录转移...
在数据库查询的时候,我们有时有这样的需求,就是要找出数据表里指定范围行内的数据记录,比如说要找出数据表里第10行到第20行的这10条数据,那么我们怎么来实现呢?  按照通常的方法是实现不了的,我们得借助于临时表以及一个函数来实现  代码如下:  Select no=Identity(int,1,1),* Into #temptable From...
标签: SQLServer
  【「Microsoft SQL Server 7.0」以下简称「SQL Server 7.0」】 在SQL Server 7.0中如何不重启SQL Server服务,即可循环errorlog(错误日志)?(New) 在SQL Server 7.0中如果要cycle errorlog,(即重新产生一个新的errorlog,errorlog变成errorlog.1,errorlog.1变成errorlog.2,...)但不重新激活SQL Server Service,在SQL Server 7.0...

经验教程

602

收藏

48
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部