详细介绍SQL交叉表的实例
2009-09-24 10:08
399 查看
数据库基于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 交叉表语句的实现: 用于:交叉表的列数是确定的 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 运行结果: 插入数据的另一种写法: Insert Class select N'张三',N'国語',78 union all select N'张三',N'数学',87 union all select N'张三',N'英語',82 union all select N'张三',N'物理',90 union all select N'李四',N'国語',65 union all select N'李四',N'数学',77 union all select N'李四',N'英語',65 union all select N'李四',N'物理',85 |
相关文章推荐
- 详细介绍SQL交叉表的实例
- 详细介绍SQL交叉表的实例 (转载)
- 详细介绍SQL交叉表的实例 (转载)
- 详细介绍SQL交叉表的实例
- 详细介绍SQL交叉表的实例
- 详细介绍SQL交叉表的实例
- Intent详细介绍及使用实例
- [转]Iptables 规则 一些简单实例和详细介绍
- Iptables 规则 一些简单实例和详细介绍
- SQL多表连接查询(详细实例)
- Java自带的线程池ThreadPoolExecutor详细介绍说明和实例应用
- Java自带的线程池ThreadPoolExecutor详细介绍说明和实例应用
- PHP编程 SSO详细介绍及简单实例
- linux awk 内置函数详细介绍(实例)
- Spark SQL中对Json支持的详细介绍
- 微信小程序 实战实例开发流程详细介绍
- 详细介绍用JBuilder9开发的Struts实例
- 基于PHP Socket配置以及实例的详细介绍
- Linux od命令详细介绍及用法实例