问题描述

我们现在有一张表titles,共有4个字段,分别是emp_no(员工编号),title(职位),from_date(起始时间),to_date(结束时间),记录的是员工在某个时间段内职位名称,因为会存在升职,转岗之类的,里面emp_no可能会对应多个职位,我们现在要取到所有员工最近的职位信息,包括离职员工。


本文介绍两种方法去实现结果:

方法一

嵌套一个group by+max()子查询获取最近的职位信息。

思路
  1. 通过对emp_no分组取每个emp_no对应的最大的from_date;
SELECT
emp_no,
max( from_date ) AS max_date
FROM
titles
GROUP BY
emp_no

结果如下:

  1. 通过查询出来的最大的from_date取筛选最近的的一条职位信息。
SELECT
t.emp_no,
t.title
FROM
titles t
LEFT JOIN ( SELECT emp_no, max( from_date ) AS max_date FROM titles GROUP BY emp_no ) et
ON t.emp_no = et.emp_no AND t.from_date = et.max_date

结果如下:


方法二

通过rank over partition by函数实现,这个目前是Oracle独有的函数,如果你用的是mysql或者sql server就没办法使用了。

语法

功能:在原有表的基础上加上一个根据条件排序的伪列。

SELECT
*,
RANK() OVER (PARTITION BY emp_no ORDER BY from_date DESC) AS rank
FROM
titles

RANK() OVER (PARTITION BY emp_no ORDER BY from_date DESC) AS rank表示把表根据emp_no进行分区,然后在分区内根据from_date进行降序排列,排序结果生成一列命名为rank。

我们之前在问题里面提到了一个emp_no会对应多条职位信息,然后对于每个emp_no的记录进行一个降序排列,接下来我们只需要把上面的结果当成一个子查询然后筛选rank = 1 就好了。

完整代码如下
SELECT
*
FROM
( SELECT *, RANK ( ) OVER ( PARTITION BY emp_no ORDER BY from_date DESC ) AS rank FROM titles ) r
WHERE
r.rank = '1'

由于我笔记本只装了mysql的环境,所以就没法给各位展示效果了。


综上,如果各位目前使用的是Oracle,推荐各位使用方法二:

  • 方法二容错率高,如果titles表里面有两条记录emp_no和from_date都是一样的,方法一就会报错了,单条子查询返回多行;
  • 方法二还可以实现取第二条,第三条等等的记录,方法一只有一个最大或者最小可供选择。

peace~

最新文章

  1. 精简版StringBuilder,提速字符串拼接
  2. vmware linux centos安装
  3. log4net按时间日期,文件大小和个数生成日志文件
  4. Human Gene Functions
  5. replace(),indexOf(),substring(),split(),join(),——各种小知识点
  6. Excel数据通过plsql导入到Oracle
  7. VS2010/MFC编程入门之十四(对话框:向导对话框的创建及显示)
  8. 如何判断JDK是32位还是64位
  9. 苹果的HomeKit协议
  10. 分析一个socket通信: server/client
  11. iOS开发之iOS7设置状态栏字体颜色
  12. input时间输入框小解
  13. 纪中集训 Day 5
  14. EntityFramework Core不得不注意的性能优化意外收获,你会用错?
  15. 【转载】路径双反斜杠!!!Python IDLE或Python shell中切换路径 切换目录os.chdir("C:\\python37\\2019pythonshel37\\diedai")
  16. (Tcp协议)linux上netstat -atunlp后出现的数据的意思(socket状态)
  17. hive表的存储路径查找以及表的大小
  18. CentOS 安装Passenger
  19. Python Sip [RuntimeError: the sip module implements API v11.0 to v11.2 but the PyQt5.QtCore module requires API v11.3]
  20. Mybatis的初步使用

热门文章

  1. 实验吧——你真的会PHP吗?(intval范围 php中\00的利用)
  2. <人人都懂设计模式>-中介模式
  3. Nginx对图片进行防盗链
  4. Elasticsearch 报错:Fielddata is disabled on text fields by default. Set `fielddata=true` on [`your_field_name`] in order to load fielddata in memory by uninverting the inverted index.
  5. C#中Equals 与== 的区别
  6. vs2017无法查看类图
  7. 22-C#笔记-预编译指令
  8. crystalreport使用方法
  9. 【java异常】 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.emptech.db.demo.mapper.master.MOmQuotaTBMapper.findOmQuotaTB
  10. java 多态(向上转型)