频道直达
八强网 > 实务 > 制作设计 > 正文阅读
关键词

SQL Server中行转列问题的终极解决

www.8tops.com 2007-10-21 8:44:09   发布:网页教学网
媒体:网页教学网   作者:mndn_nana
 

  本文将向大家介绍 SQL Server 中行转列问题的终极解决方案,主要应用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

  执行:

  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

  得出结果:

  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)

  得出结果

  sid       语文    数学   英语

  2005001  80.0  90.0  80.0

  2005002  56.0  69.0  89.0

八强网,更多精彩在首页,
八强网首页
网友评论

发表

我也评两句
 
发文时请务必注意:
一、遵守国家相关法律规定,如 《北京地区互联网站电子公告服务倡议书》《全国人大常委会关于维护互联网安全的决定》 及中华人民共和国其他各项有关法律法规。一旦违犯法律法规,您将承担一切因您的行为而直接或间接导致的民事或刑事法律责任,本站工作人员有义务配合相关部门,提供必要的技术资料(如IP地址等)。
二、自觉遵守爱国、守法、自律、真实、文明的原则,严禁发表有人身攻击倾向、有造谣生事嫌疑的言论,严禁发表虚假广告、色情、网络传销性质的内容,本站管理人员有权删除违反规定的内容或取消违规网友的发文权限甚至删除其ID。
互联网产业作家
网站提交】【八强自荐
将八强网设为首页 将八强网添加到收藏夹 将八强网推荐给朋友 网络实名、通用网址:八强网
关于我们 - 联系合作 - 广告服务 - 友情链接 - 支持单位 - 免责声明
基于E-file技术构建 版权所有Copyright©2006 京ICP备06061834号