前事不忘,后事之师,不忘国耻!

 注册  找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2758|回复: 0

详细介绍SQL交叉表的实例

[复制链接]

详细介绍SQL交叉表的实例

[复制链接]
ehxz

主题

0

回帖

7251

积分

管理员

积分
7251
2006-12-18 22:47:40 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

×
  很简单的一个东西,见网上好多朋友问“怎么实现交叉表?”,以下是我写的一个例子,数据库基于SQL SERVER 2000。
  
  交叉表实例
  
  建表:
  
  在查询分析器里运行:
  
  CREATE TABLE [Test] (
  
  [id] [int] IDENTITY (1, 1) NOT NULL ,
  
  [name] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
  
  [subject] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
  
  [Source] [numeric](18, 0) NULL
  
  ) ON [PRIMARY]
  
  GO
  
  INSERT INTO [test] ([name],[subject],[Source]) values (N'张三',N'语文',60)
  
  INSERT INTO [test] ([name],[subject],[Source]) values (N'李四',N'数学',70)
  
  INSERT INTO [test] ([name],[subject],[Source]) values (N'王五',N'英语',80)
  
  INSERT INTO [test] ([name],[subject],[Source]) values (N'王五',N'数学',75)
  
  INSERT INTO [test] ([name],[subject],[Source]) values (N'王五',N'语文',57)
  
  INSERT INTO [test] ([name],[subject],[Source]) values (N'李四',N'语文',80)
  
  INSERT INTO [test] ([name],[subject],[Source]) values (N'张三',N'英语',100)
  
  Go
  
 

1

1

  交叉表语句的实现:
  
  用于:交叉表的列数是确定的
  
  select name,sum(case subject when '数学' then source else 0 end) as '数学',
  
  sum(case subject when '英语' then source else 0 end) as '英语',
  
  sum(case subject when '语文' then source else 0 end) as '语文'
  
  from test
  
  group by name
  
  --用于:交叉表的列数是不确定的
  
  declare @sql varchar(8000)
  
  set @sql = 'select name,'
  
  select @sql = @sql + 'sum(case subject when '''+subject+'''
  
  then source else 0 end) as '''+subject+''','
  
  from (select distinct subject from test) as a
  
  select @sql = left(@sql,len(@sql)-1) + ' from test group by name'
  
  exec(@sql)
  
  go
  
  运行结果:
  

2

2
免责申明1、欢迎访问本站,本文内容及相关资源来源于网络,版权归版权方所有!本站原创内容版权归本站所有,请勿转载!
2、本文内容仅代表作者观点,不代表本站立场,作者自负,本站资源仅供学习研究,请勿非法使用,否则后果自负!请下载后24小时内删除!
3、本文内容,包括但不限于源码、文字、图片等,仅供参考。本站不对其安全性,正确性等作出保证。但本站会尽量审核会员发表的内容。
4、如本帖侵犯到任何版权问题,请立即告知本站 ,本站将及时删除并致以最深的歉意!客服邮箱:admin@dbabbs.com
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|小黑屋|DBA论坛中国 ( 鲁ICP备20017503号-2 )

GMT+8, 2024-12-22 11:55 , Processed in 0.040642 second(s), 11 queries , MemCached On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表