mysql时间区间效率,MySQL查询:EHR中某时间范围过生日的员工

需求背景

1、要求在用户在查询界面,可以查询自定义范围期限的员工生日。

2、页面渲染的时候,默认出现近七天内要过生日的人。并发邮件提醒(发邮件提醒不在这里完成,是在其他模块,这里只描述如何查询生日的人)。

如下图案例(组件使用Element-UI):

a0e1ed08f0ef444e4dad3b42ac5a8247.png

一个是起始时间,一个是终止时间。

需求分析

生日的查询好实现,员工表中,其中有员工表的生日提醒。

这里需要注意的几个点:

1、查询生日的时候,需拆分一下时间,需要把年份去掉,只留下月日。

2、跨年查询。

第2点要是搁在普通的时间,用到的很少,现在是跨年,硬性需求。而且,生日查询嘛,一般查询的都是近期的,没有查询跨度半年或者是好几个月的,这样不太符合一般性的需求。

具体实现

跨年查询我有两种方法,我再Mybatis中,用的是第一种。

方法一:前端往后端传时间的时候,时间取值转换成字符串,只截取月日四个数字,比如'1225',然后传给后端。后端拿到,在MySQL语句处理的时候,我拿到员工的生日,一样截取月日。

这样就能匹配起来。单纯这样子,还无法对跨年进行处理。

方法二:取出员工的生日,比较与现在输入查询的年份【用户输入的不一定是今年哦~所以,不能取现在的时间】的[差距多少年],也就是算了算他多少岁,然后把他生日的年份加上+[[差距多少年]],就是所选查询日期的起始年份。

例如,经过方法二的查询,本来张三的生日是1990-12-25,查询的时候,加入输入的起始时间是:【2018-09-08】,他的生日会变成【2018-12-25】。

同样,查询第二个时间点,终止时间,也这样去写,可以解决跨年的问题。

那么方法一中的跨年问题如何去解决呢?我没有去判断时间点,是不是终止的时间日期要比起始日期要小之类的。

MySQL语句

这是在navicat中执行的语句,使用union all链接结果。这个其实看出的不明显,第二张图我放上MyBatis映射文件中的代码。

627c0b902c539a0712e4cd452232c469.png

在查询起始时间大于终止时间的时候,第一个select,查询的结果集是空,这里跨年处理我是将时间节点截断的。BETWEEN #{data.startDataBirthdayPoint} AND '1231'BETWEEN '0101' AND #{data.endDataBirthdayPoint}

用这两个来处理跨年。不管用户选择是哪一年,都好使。

下面是第二种方法的代码:

176965ff3bc539eb1b1b22319df1b076.png

这个方式,单纯的查询,能够实现我想要的需求,我放到MyBatis映射文件去查询的时候,报错,具体的原因我没有去细查。

如果我解决了MyBatis映射文件的错误,我似乎也不会选择这个方法,其中里面的方法太多,假如人数很多的话,铁定会影响效率。

我推荐第一种,简单,有效。

基于SSM框架的智能家政保洁预约系统,是一个旨在提高家政保洁服务预约效率和管理水平的平台。该系统通过集成现代信息技术,为家政公司、家政服务人员和消费者提供了一个便捷的在线预约和管理系统。 系统的主要功能包括: 1. **用户管理**:允许消费者注册、登录,并管理他们的个人资料和预约历史。 2. **家政人员管理**:家政服务人员可以注册并更新自己的个人信息、服务类别和服务时间。 3. **服务预约**:消费者可以浏览不同的家政服务选项,选择合适的服务人员,并在线预约服务。 4. **订单管理**:系统支持订单的创建、跟踪和管理,包括订单的确认、完成和评价。 5. **评价系统**:消费者可以在家政服务完成后对服务进行评价,帮助提高服务质量和透明度。 6. **后台管理**:管理员可以管理用户、家政人员信息、服务类别、预约订单以及处理用户反馈。 系统采用Java语言开发,使用MySQL数据库进行数据存储,通过B/S架构实现用户与服务的在线交互。系统设计考虑了不同用户角色的需求,包括管理员、家政服务人员和普通用户,每个角色都有相应的权限和功能。此外,系统还采用了软件组件化、精化体系结构、分离逻辑和数据等方法,以便于未来的系统升级和维护。 智能家政保洁预约系统通过提供一个集的平台,不仅方便了消费者的预约和管理,也为家政服务人员提供了一个展示和推广自己服务的机会。同时,系统的后台管理功能为家政公司提供了强大的数据支持和决策辅助,有助于提高服务质量和管理效率。该系统的设计与实现,标志着家政保洁服务向现代化和网络化的转型,为管理决策和控制提供保障,是行业发展的重要里程碑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值