MySQL语句与Java代码实现按需过滤企业员工的资质证书

概要

在企业ERP中,每位员工拥有多个资质证书,资质证书有种类、名称和登记时间,以及变动时间和结束时间的主要属性;

现在有一个需求,员工在系统查看自己的信息之时:同一种类、同一名称、同一登记时间的资质证书,取变动时间最近的显示出来,其余的不显示;

数据源:SAP生产系统通过RPC的方式获取;

正文

下面是表的主要结构(手机显示可能存在换上现象):

字段名称

类型

备注

employee_special_uuid

varchar

uuid

employee_id

varchar

员工ID

special_operations_type

varchar

证书类型

special_operations_project

varchar

证书项目(名字)

special_operations_record_date

date

登记日期

sp_begin_date

date

变动日期

sp_end_date

date

结束日期

这个地方如果给最新的那条记录,加一个标识,比如加个字段显示x,过滤的时候用sql直接出结果,挺方便的,我问过SAP开发的同事:no;

思路

代码没有新颖的,只说一下我的思路(也可能有些问题):

1、首先用MySQL语句GROUP BY 已经三个字段的结果分组;分组的结果:按照需求将数据分成一组一组的,每组中的数据并按照变动时间,最新的在上面(也就是符合要求的那一条,在最上面) 2、Java代码拿到数据集,进行处理; 3、刚才上面说了,第一条是符合要求的,就遍历数据集,每组的数据集,用List的特点,将所有元素置为相同的元素,与第一条保持一致; 4、去重;

通过简单的方式,实现了这个小的需求;

总结

总结成简单的话, 1、先分组,分组的数据按照时间降序排列; 2、再用Java代码处理List,将list的元素用遍历的方式将值设置为一致; 3、将list去重;

原文发布于微信公众号 - 数据库SQL(SQLdba)

原文发表时间:2019-03-08

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券