| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 685 人关注过本帖
标题:这样的sql怎么写?
只看楼主 加入收藏
aleckhao
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2008-2-10
收藏
 问题点数:0 回复次数:5 
这样的sql怎么写?
例如表如下:
部门      人员    属性状态
部门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怎么写,怎么写查询效果最优,因为数据量很大,谢谢
搜索更多相关主题的帖子: 人员 
2012-08-08 10:02
kaijin1115
Rank: 2
等 级:论坛游民
威 望:1
帖 子:12
专家分:14
注 册:2012-1-27
收藏
得分:0 
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   
2012-08-25 14:26
不知123
Rank: 2
等 级:论坛游民
帖 子:20
专家分:14
注 册:2012-9-3
收藏
得分:0 
以下是引用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 部门
显示的结果就是你要求的结果,请测试,谢谢!!
2012-09-04 23:28
Sunpeng_Bccn
Rank: 2
等 级:论坛游民
威 望:2
帖 子:19
专家分:34
注 册:2012-8-4
收藏
得分:0 
学习了
2012-09-08 01:29
woaishujuku
Rank: 2
等 级:论坛游民
威 望:1
帖 子:8
专家分:17
注 册:2012-9-26
收藏
得分:0 
上面漏掉了一部分。。正确的应该是
原始表就以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结果是一样的




2012-09-26 16:08
jimmynie
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2012-11-3
收藏
得分:0 
如果是SQL 2005以上,可以使用PIVOT,具体看帮助
2012-11-03 13:04
快速回复:这样的sql怎么写?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.018557 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved