首页 > 数据库技术 > 详细

sql5

时间:2020-02-05 22:27:36      阅读:85      评论:0      收藏:0      [点我收藏+]

 题目描述

查找当前薪水(to_date=‘9999-01-01‘)排名第二多的员工编号emp_no、薪水salary、last_name以及first_name,不准使用order by

    CREATE TABLE `employees` (
    `emp_no` int(11) NOT NULL,
    `birth_date` date NOT NULL,
    `first_name` varchar(14) NOT NULL,
    `last_name` varchar(16) NOT NULL,
    `gender` char(1) NOT NULL,
    `hire_date` date NOT NULL,
    PRIMARY KEY (`emp_no`));
    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`));


解答一:
思路:首先查到最高薪水的记录,然后去掉此记录的信息
最后在剩下的记录中查到最高的记录即为薪水排名第二的员工的信息了。

最高薪水:
select max(salary) from salaries where to_date=‘9999-01-01‘
除去最高薪水: 
select * from salaries where salary!=(
             select max(salary) from salaries where to_date=‘9999-01-01‘
        )
1
剩下的最高薪水: 
select max(salary) from (
        select * from salaries where salary!=(
            select max(salary) from salaries where to_date=‘9999-01-01‘
        )
    ) where to_date=‘9999-01-01‘
最后的完整代码:

    select s.emp_no,s.salary,e.last_name,e.first_name from salaries s,employees e 
    where s.emp_no=e.emp_no 
    and s.to_date=‘9999-01-01‘ 
    and s.salary=(
    select max(salary) from (
    select * from salaries where salary!=(
    select max(salary) from salaries where to_date=‘9999-01-01‘
    )
    ) where to_date=‘9999-01-01‘
    );
    
解答二:
   也可以采用MAX()函数的嵌套

    select e.emp_no, Max(s.salary) as salary, e.last_name, e.first_name
    from employees e,salaries s
    where e.emp_no=s.emp_no 
    and s.to_date=‘9999-01-01‘
    and s.salary!= (select Max(salary) from salaries where to_date=‘9999-01-01‘)
解答三:
   下面的解答思路是,借鉴了mysql分组取每组前几条记录的方法,优点在于可以取任意多薪水的员工,
缺点是不容易理解

    select s.emp_no, s.salary, e.last_name, e.first_name from salaries s join employees e on s.emp_no=e.emp_no
    and s.to_date=‘9999-01-01‘
    and s.emp_no=(select s1.emp_no from salaries s1 join salaries s2 on s1.salary<=s2.salary 
      and s1.to_date=‘9999-01-01‘ and s2.to_date=‘9999-01-01‘
      group by s1.emp_no having count(1) = 2);

参考资料来源:牛客网

sql5

原文:https://www.cnblogs.com/fruit1024/p/12266743.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!