求按部门分类统计的sql语句
时间:2011-09-01
来源:互联网
             表:tab
id 姓名 部门名称 学历 职称
1 张三 dept1 本科 初级
2 李四 dept2 本科 初级
3 王五 dept3 硕士 中级
4 张四 dept1 博士 高级
5 小红 dept1 本科 初级
6 小丽 dept2 硕士 中级
根据上面的表实现分类统计实现如下结果:
部门名称 本科人数 硕士人数 博士人数 初级职称人数 中级职称人数 高级职称人数
dept1 2 0 1 2 0 1
dept2 1 1 0 1 1 0
dept3 0 1 0 0 1 0
请教高手,该如何组织sql语句呢?
            id 姓名 部门名称 学历 职称
1 张三 dept1 本科 初级
2 李四 dept2 本科 初级
3 王五 dept3 硕士 中级
4 张四 dept1 博士 高级
5 小红 dept1 本科 初级
6 小丽 dept2 硕士 中级
根据上面的表实现分类统计实现如下结果:
部门名称 本科人数 硕士人数 博士人数 初级职称人数 中级职称人数 高级职称人数
dept1 2 0 1 2 0 1
dept2 1 1 0 1 1 0
dept3 0 1 0 0 1 0
请教高手,该如何组织sql语句呢?
作者: yanli821014 发布时间: 2011-09-01
             SQL code
from tab
Group by 部门名称
            select 部门名称, sum(if(学历='本科',1,0)) as 本科人数, Sum(if(学历='硕士',1,0)) as 硕士人数, Sum(if(学历='博士',1,0)) as 博士人数, sum(if(职称='初级',1,0)) as 初级职称人数, sum(if(职称='中级',1,0)) as 中级职称人数, sum(if(职称='高级',1,0)) as 高级职称人数
from tab
Group by 部门名称
作者: ACMAIN_CHM 发布时间: 2011-09-01
             select 部门名称,sum(case when 学历='本科' then 1 else 0 end) as 本科人数,
Sum(case when 学历='硕士'then 1 else 0 end) as 硕士人数,
Sum(case when 学历='博士'then 1 else 0 end) as 博士人数,
sum(case when 职称='初级'then 1 else 0 end) as 初级职称人数,
sum(case when 职称='中级'then 1 else 0 end) as 中级职称人数,
sum(case when 职称='高级'then 1 else 0 end) as 高级职称人数
from tt Group by 部门名称
            Sum(case when 学历='硕士'then 1 else 0 end) as 硕士人数,
Sum(case when 学历='博士'then 1 else 0 end) as 博士人数,
sum(case when 职称='初级'then 1 else 0 end) as 初级职称人数,
sum(case when 职称='中级'then 1 else 0 end) as 中级职称人数,
sum(case when 职称='高级'then 1 else 0 end) as 高级职称人数
from tt Group by 部门名称
作者: WWWWA 发布时间: 2011-09-01
 相关阅读 更多  
      
    热门阅读
-  
 office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
          阅读:74
 -  
 如何安装mysql8.0
          阅读:31
 -  
 Word快速设置标题样式步骤详解
          阅读:28
 -  
 20+道必知必会的Vue面试题(附答案解析)
          阅读:37
 -  
 HTML如何制作表单
          阅读:22
 -  
 百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
          阅读:31
 -  
 ET文件格式和XLS格式文件之间如何转化?
          阅读:24
 -  
 react和vue的区别及优缺点是什么
          阅读:121
 -  
 支付宝人脸识别如何关闭?
          阅读:21
 -  
 腾讯微云怎么修改照片或视频备份路径?
          阅读:28
 















