题
目
描
述
:
\color{blue}题目描述:
题目描述:
查找薪水涨幅超过15次的员工号emp_no以及其对应的涨幅次数t
CREATE TABLE `salaries` (
`emp_no` int(11) NOT NULL,
`salary` int(11) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`from_date`));
输
入
描
述
:
\color{blue}输入描述:
输入描述:
无
输
出
描
述
:
\color{blue}输出描述:
输出描述:
思
路
分
析
:
\color{blue}思路分析:
思路分析:
这道题的关键是在于理解“涨幅次数”,正常的思维应该是每升一次工资认为一次涨幅,但是测试数据的数据认为员工在salaries表中有多少条记录就涨了多少次。所以我们只要按照emp_no员工号进行分组,如果组内元素超过15就是符合条件的记录。
代 码 实 现 : \color{blue}代码实现: 代码实现:
#2、count(*)计算组内记录条数,别名t
select emp_no, count(*) t
from salaries
#1、按照emp_no分组
group by emp_no
#3、分组后筛选出涨了超过15次的员工记录
having t > 15;
博
客
推
荐
:
\color{blue}博客推荐:
博客推荐:
此题涉及到MySQL中的分组查询,请参考我的专栏:
MySQL从入门到精通之分组查询