题目描述

查找所有员工入职时候的薪水情况,给出emp_no以及salary, 并按照emp_no进行逆序
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`));

输出描述:

emp_no salary
10011 25828
省略 省略
10001

60117

解答1:

SQL:

select e.emp_no,s.salaryfrom employees e join salaries son    e.emp_no=s.emp_no and e.hire_date=s.from_dateorder by e.emp_no desc

 运行 19ms-22ms

1、由于测试数据中,salaries.emp_no 不唯一(因为号码为 emp_no 的员工会有多次涨薪的可能,所以在 salaries 中对应的记录不止一条),employees.emp_no 唯一,即 salaries 的数据会多于 employees,因此需先找到 employees.emp_no 在 salaries 表中对应的记录salaries.emp_no,则有限制条件 e.emp_no = s.emp_no
2、根据题意注意到 salaries.from_date 和 employees.hire_date 的值应该要相等,因此有限制条件 e.hire_date = s.from_date
3、根据题意要按照 emp_no 值逆序排列,因此最后要加上 ORDER BY e.emp_no DESC
4、为了代码良好的可读性,运用了 Alias 别名语句,将 employees 简化为 e,salaries 简化为s,即 employees AS e 与 salaries AS s,其中 AS 可以省略
链接:https://www.nowcoder.com/questionTerminal/23142e7a23e4480781a3b978b5e0f33a 牛客网优秀解答 
解答2:(来自牛客网 优秀解答)
不要要连接 直接用工资表
select emp_no,salary from salaries
group by emp_no having(min(from_date))
order by emp_no desc

对其直接进行分组 找出其最小的入职时间  运行时间在 17ms

转载于:https://www.cnblogs.com/kexiblog/p/10647677.html

SQL-6查找所有员工入职时候的薪水情况,给出emp_no以及salary, 并按照emp_no进行逆序...相关推荐

  1. SQL实战之查找所有员工入职时候的薪水情况

    题目描述 查找所有员工入职时候的薪水情况,给出emp_no以及salary, 并按照emp_no进行逆序 CREATE TABLE `employees` ( `emp_no` int(11) NOT ...

  2. 刷题日记-SQL 查找最晚入职员工的所有信息

    牛客网 SQL1 查找最晚入职员工的所有信息 描述 有一个员工employees表简况如下: 请你查找employees里最晚入职员工的所有信息,以上例子输出如下: 示例: #如果数据库中存在empl ...

  3. SQL刷题——查找最晚入职员工的所有信息

    题目 牛客题霸-SQL篇 SQL1 查找最晚入职员工的所有信息 思路 查询入职时间最晚的员工信息,即筛选出条件为hire_date 最大的员工信息 注意 聚合函数不能直接用在 WHERE 后做筛选条件 ...

  4. 《数据库SQL实战》查找最晚入职员工的所有信息

    题目:查找最晚入职员工的所有信息 CREATE TABLE employees ( emp_no int(11) NOT NULL, birth_date date NOT NULL, first_n ...

  5. [SQL]实战之查找员工编号emp_no为10001其自入职以来的薪水salary涨幅值growth

    题目描述 查找员工编号emp_no为10001其自入职以来的薪水salary涨幅值growth CREATE TABLE salaries ( emp_no int(11) NOT NULL, sal ...

  6. SQL实战之查找最晚入职员工的所有信息

    题目描述 CREATE TABLE `employees` ( `emp_no` int(11) NOT NULL, `birth_date` date NOT NULL, `first_name` ...

  7. 数据库SQL实战-查找所有员工自入职以来的薪水涨幅情况(mysql)

    1. 查找所有员工自入职以来的薪水涨幅情况 1.1 题目描述 有一个员工表employees简况如下: 有一个薪水表salaries简况如下: 请你查找所有员工自入职以来的薪水涨幅情况,给出员工编号e ...

  8. 查找最晚入职员工的所有信息

    题目链接 题目描述 查找最晚入职员工的所有信息 CREATE TABLE `employees` ( `emp_no` int(11) NOT NULL, `birth_date` date NOT ...

  9. 查找在职员工自入职以来的薪水涨幅情况

    题目背景: 查找在职员工自入职以来的薪水涨幅情况,给出在职员工编号emp_no以及其对应的薪水涨幅growth,并按照growth进行升序. to_date为薪资调整某个结束日期,或者为离职日期,to ...

最新文章

  1. 检查oracle安装,oracle安装前环境检查
  2. 怎么改掉科学计数法_马拉松猝死频发为哪般——听听冠军们怎么说
  3. 1.18.3.Flink Catalog介绍、Catalog 定义、Catalog 的实现、Catalog 使用举例
  4. 在html页面中引入公共的头部和底部
  5. 检测到python编程环境中存在多个版本_linux下多个python版本怎么管理?
  6. C语言指针变量的定义和使用
  7. k8s高可用集群_搭建高可用集群(实现方式介绍)---K8S_Google工作笔记0054
  8. MySQL之SQL优化详解(一)
  9. Diagrams for Mac(原生流程图制作工具)
  10. 在线代码图片生成工具carbon
  11. 网易云api普通评论爬取的反馈
  12. somachine3.1安装包和安装方法
  13. 验证牛顿公式的局部收敛性,并找到对于牛顿公式不收敛(发散)的函数,比较二分法与牛顿公式的收敛速度
  14. 新建工程,如何通过git上传到阿里云code
  15. 知乎微信小程序广告真的猛的一塌糊涂
  16. 计算机网络(六)——因特网中的电子邮件
  17. 灵魂深处的眼泪 秋枫
  18. vb.net Encoding类 编码解码
  19. 初学Python:encode、decode和Unicode等
  20. Python中序列的累积计算

热门文章

  1. 聚合登录平台网站源码 PHP聚合登录源码
  2. 百度SEO Keyword Surfer v0.3.7(关键词优化)
  3. Linux-Ubuntu部署Springboot项目应用到生产环境(jar方式)
  4. 浅谈C# Socket编程及C#如何使用多线程
  5. WordPress数据库管理中五个实用的phpMyAdmin技巧
  6. GMaps.js:让你快速集成 Google Maps 服务的 jQuery 插件
  7. 使用SSH更新WordPress
  8. 怎么样用 Google Analytics 区分 Google Shopping 页的流量
  9. jQuery函数 - 左右抖动效果,用于提示
  10. magento创建自定义页面 (Bestseller实例) Bestseller products in Magento