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


本文摘自PHP中文网,作者little bottle,侵删。

在企业ERP中,每位员工拥有多个资质证书,资质证书有种类、名称和登记时间,以及变动时间和结束时间的主要属性;现在有一个需求,员工在系统查看自己的信息之时:同一种类、同一名称、同一登记时间的资质证书,取变动时间最近的显示出来,其余的不显示。

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

正文

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

QQ截图20190408103236.png

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

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

1、首先用MySQL语句GROUP BY 已经三个字段的结果分组;分组的结果:按照需求将数据分成一组一组的,每组中的数据并按照变动时间,最新的在上面(也就是符合要求的那一条,在最上面)

2、Java代码拿到数据集,进行处理;

3、刚才上面说了,第一条是符合要求的,就遍历数据集,每组的数据集,用List的特点,将所有元素置为相同的元素,与第一条保持一致;

4、去重;

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

总结

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

【推荐课程:MySQL教程】

以上就是MySQL语句与Java代码实现按需过滤企业员工的资质证书的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

触发器什么时候执行

实例详解阿里云下配置mysql远程连接步骤

只会sql能找什么工作?

mysql8.0.19安装教程

mysql中create as 和create like有什么区别?(对比介绍)

mysql8.0.20下载安装及遇到的问题(图文详解)

布尔教育燕十八mysql优化视频资料分享

mysql8.0.11安装配置方法图文教程 mysql8.0新密码认证方式

mysql怎么改字符编码?

mysql如何删除多个表格数据库数据

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...