日期:2014-05-18  浏览次数:20477 次

请问下如下的视图该怎么创建呢?
如图三张表


生成的Sql语句如下:
SQL code
SELECT TOP 100 PERCENT dbo.athlete.name AS athleteName, 
      dbo.unitInfo.name AS unitName, dbo.unitInfo.guide, dbo.unitInfo.coach, 
      dbo.unitInfo.worker, dbo.unitInfo.teamDoctor, dbo.athlete.userId, dbo.athlete.id
FROM dbo.athlete INNER JOIN
      dbo.unitGroup ON dbo.athlete.unitGroup = dbo.unitGroup.id INNER JOIN
      dbo.unitInfo ON dbo.unitGroup.unitInfo = dbo.unitInfo.id
ORDER BY dbo.unitInfo.name


查询出的数据如下:


现在要统计出如下的结果:

男运动员数 女运动员数 领队数 教练数 队医数
江岸区 2 1 2 6 1
硚口区 1 2 1 1 1
主要是教练,这里面的字符串 是用顿号分开的,
例如 
SQL code
蔡幸福、金燕妮、蔡幸福、金燕妮、蔡幸福、金燕妮


这是6个人~

上面的各项直接用count 的话,列出的是所有的记录数呢,~

------解决方案--------------------
SQL code
Guide=len(Guide)-len(replace(Guide,'、',''))+1
Coach=len(Coach)-len(replace(Coach,'、',''))+1

------解决方案--------------------
SQL code

--行列互转
--摘自中国风博客,引用请标明内容来源
--1、行换列
if object_id('Class') is not  null
    drop table Class
Go
Create table Class(
[Student] nvarchar(2),
[Course] nvarchar(2),
[Score] int)
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 
Go

--2000方法:
--动态:
declare @s nvarchar(4000)
set @s=''
Select @s=@s+','+quotename([Course])+'=max(case when [Course]='    
   
    +quotename([Course],'''')+' then [Score] else 0 end)'
from 
    Class group by[Course]
--select @s
exec('select [Student]'+@s+' from Class group by [Student]')
--生成静态:
select 
    [Student],
    [数学]=max(case when [Course]='数学' then [Score] else 0 end),
    [物理]=max(case when [Course]='物理' then [Score] else 0 end),
    [英语]=max(case when [Course]='英语' then [Score] else 0 end),
    [语文]=max(case when [Course]='语文' then [Score] else 0 end) 
from 
    Class 
group by [Student]
GO
--动态:

declare @s nvarchar(4000)
Select @s=isnull(@s+',','')+quotename([Course]) from Class group by[Course]
select @s
exec('select * from Class pivot (max([Score]) for [Course] in('+@s+'))b')

--生成静态:
select * 
from 
    Class 
pivot 
    (max([Score]) for [Course] in([数学],[物理],[英语],[语文]))b

--生成格式:
/*
Student 数学         物理         英语         语文
------- ----------- ----------- ----------- -----------
李四     77          85          65          65
张三     87          90          82          78

(2 行受影响)
*/

go
--加上总成绩(学科平均分)

--2000方法:
--动态:

declare @s nvarchar(4000)
set @s=''
Select @s=@s+','+quotename([Course])+'=max(case when [Course]='+quotename([Course],'''')+'then [Score] else 0 end)'
from Class group by[Course]
exec('select [Student]'+@s+',[总成绩]=sum([Score])  from Class group by [Student]')--加多一列(学科平均分用avg([Score]))

生成动态:

select 
    [Student],
    [数学]=max(case when [Course]='数学' then [Score] else 0 end),
    [物理]=max(case when [Course]='物理' then [Score] else 0 end),
    [英语]=max(case when [Course]='英语' then [Score] else 0 end),
    [语文]=max(case when [Course]='语文' then [Score] else 0 end),
    [总成绩]=([Score]) --加多一列(学科平均分用avg([Score]))
from 
    Class 
group by [Student]

go

--2005方法:

动态:

declare @s nvarchar(4000)
Select  @s=isnull(@s+',','')+quotename([Course]) from Class group by[Course] 
--isnull(@s+',','') 去掉字符串@s中第一个逗号

exec('select [Student],'+@s+',[总成绩] from (select *,[总成绩]=sum([Score])over(partition by [Student]) from Class) a 
pivot (max([Score]) for [Course] in('+@s+'))b ')

--生成静态:

select 
    [Student],[数学],[物理],[英语