注册 登录
编程论坛 SQL Server论坛

这样的sql怎么写?

aleckhao 发布于 2012-08-08 10:02, 687 次点击
例如表如下:
部门      人员    属性状态
部门1       a       1
部门1       b       2
部门1       c       1
部门1       d       3
部门2       e       2
部门2       f       1
部门2       g       2
部门3       h       3
部门3       i       1
部门3       j       1
怎样写一个sql,得出如下的结果
部门   属性状态1     属性状态2    属性状态3
部门1     2            1             1
部门2     1            2             0
部门3     2            0             1
即统计每个部门个属性的人员数量,哪位能帮说下这样的sql怎么写,怎么写查询效果最优,因为数据量很大,谢谢
5 回复
#2
kaijin11152012-08-25 14:26
create table test1(部门 varchar(10),人员 nvarchar(10),属性状态 int)  //创建测试表
insert into test1 values('部门1' , N'a' , N'1')
insert into test1 values('部门1' , N'b' , N'2')
insert into test1 values('部门1' , N'c' , N'1')
insert into test1 values('部门1' , N'd' , N'3')
insert into test1 values('部门2' , N'e' , N'2')
insert into test1 values('部门2' , N'f' , N'1')
insert into test1 values('部门2' , N'g' , N'2')
insert into test1 values('部门3' , N'h' , N'3')
insert into test1 values('部门3' , N'i' , N'1')
insert into test1 values('部门3' , N'j' , N'1')

select 部门,属性状态,count(人员)as 计数 from test1 group by 部门,属性状态 order by 部门
查询结果:
 部门  属性状态  计数
部门1     1       2   
部门1     2       1   
部门1     3       1   
部门2     1       1   
部门2     2       2   
部门3     1       2   
部门3     3       1   
#3
不知1232012-09-04 23:28
以下是引用kaijin1115在2012-8-25 14:26:02的发言:

create table test1(部门 varchar(10),人员 nvarchar(10),属性状态 int)  //创建测试表
insert into test1 values('部门1' , N'a' , N'1')
insert into test1 values('部门1' , N'b' , N'2')
insert into test1 values('部门1' , N'c' , N'1')
insert into test1 values('部门1' , N'd' , N'3')
insert into test1 values('部门2' , N'e' , N'2')
insert into test1 values('部门2' , N'f' , N'1')
insert into test1 values('部门2' , N'g' , N'2')
insert into test1 values('部门3' , N'h' , N'3')
insert into test1 values('部门3' , N'i' , N'1')
insert into test1 values('部门3' , N'j' , N'1')

select 部门,属性状态,count(人员)as 计数 from test1 group by 部门,属性状态 order by 部门
查询结果:
 部门  属性状态  计数
部门1     1       2   
部门1     2       1   
部门1     3       1   
部门2     1       1   
部门2     2       2   
部门3     1       2   
部门3     3       1   
前面建表用二楼的,本人较懒,能省就省啦!!!
后面的语句:
select 部门,sum(case 属性姿态 when '1' then 1 else 0 end) as 属性状态1,sum(case 属性姿态 when '2' then 1 else 0 end) as 属性状态2,sum(case 属性姿态 when '3' then 1 else 0 end) as 属性状态3
from test1
group by 部门
order by 部门
显示的结果就是你要求的结果,请测试,谢谢!!
#4
Sunpeng_Bccn2012-09-08 01:29
学习了
#5
woaishujuku2012-09-26 16:08
上面漏掉了一部分。。正确的应该是
原始表就以2楼的为准
declare @tt(部门 varchar(50),属性状态 int,计数 int)
insert into @tt(部门,属性状态,计数)select 部门,属性状态,count(人员) as 计数 from 原始表名 group by 部门,属性状态 order by 部门
查询结果:
部门  属性状态  计数
部门1     1       2   
部门1     2       1   
部门1     3       1   
部门2     1       1   
部门2     2       2   
部门3     1       2   
部门3     3       1  
这是第一步,接着第二步, 对这表进行行转列操作,运用case when 转化
select 部门, max(case 属性状态 when 1 then 计数 else 0 end) 属性状态1,
             max(case 属性状态 when 2 then 计数 else 0 end )属性状态2,
             max(case 属性状态 when 3 then 计数 else 0 end) 属性状态3
 from @tt group by 部门
得到结果
部门   属性状态1     属性状态2    属性状态3
部门1     2            1             1
部门2     1            2             0
部门3     2            0             1
或者不创建虚拟表,直接用select into 先创个查询表 #2 select 部门,属性状态,count(人员) as 计数 into #2 from 原始表名 group by 部门,属性状态 order by 部门
后面跟第二步一样.聚合函数max换成sum结果是一样的




#6
jimmynie2012-11-03 13:04
如果是SQL 2005以上,可以使用PIVOT,具体看帮助
1