版權聲明:csdn是本blog托管服務提供商。如本文牽涉版權問題,csdn不承擔相關責任,請版權擁有者直接與文章作者聯系解決。
sql交叉表實例
很簡單的一個東西,見網上好多朋友問“怎么實現交叉表?”,以下是我寫的一個例子,數據庫基于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
450)this.width=450" o:title="sql2">
交叉表語句的實現:
--用于:交叉表的列數是確定的
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
運行結果:
450)this.width=450" o:title="sql">