表: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语句呢?
解决方案 »
- MY sql 灵异事件
- 求助高手,昨天晚上公司断电,服务器关,今天早上启动MYSQL服务直接报错,(贴上错误信息)
- 急,在线等!! ● 向ACMAIN_CHM、zuoxingyu求助 ● 以下几种关于日志表的设计那一种更有效率
- 在表里增加了四个TEXT类型的字段后MYSQL就死了,起不来
- 急,在线等==mysqldump时如果密码带有*,怎么处理?
- MSSQL数据导入到MySQL的TEXT型字段的问题
- mysql,cross 连接查询
- MYSQL重启后马上自动挂,急求解
- 两张表联合查询
- 小白问个数据库表的问题,希望大神帮忙
- 查询语句 求高手赐教
- sql语句中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 部门名称
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 部门名称