文章目录
- 写在前面
- 时间相关的减法操作
- 两个date日期相减获得时间差
- lacaltime和date做差
- sql语句,select子句当作where查询的条件
写在前面
出来创业也一年多了,感觉这一年,后端的开发荒废了很多,都快不如专注做后端开发两三年的学弟学妹们了,逼着自己开了这个专栏,让自己坚持把每天开发的收获写一写。
时间相关的减法操作
两个date日期相减获得时间差
public static String timeDistance(Date endDate, Date startTime){long nd = 1000 * 24 * 60 * 60;long nh = 1000 * 60 * 60;long nm = 1000 * 60;// long ns = 1000;// 获得两个时间的毫秒时间差异long diff = endDate.getTime() - startTime.getTime();// 计算差多少天long day = diff / nd;// 计算差多少小时long hour = diff % nd / nh;// 计算差多少分钟long min = diff % nd % nh / nm;// 计算差多少秒//输出结果// long sec = diff % nd % nh % nm / ns;return day + "天" + hour + "小时" + min + "分钟";}
思路就是获得2个日期的毫秒差异,然后对每天的毫秒数目做除法,获得天的差距。如果对天取摩,就是相差多少小时的毫秒数,再对小时的毫秒做除法,就是相差多少小时。以此类推。就可以得到差距多少分,多少秒。然后把前面的天小时,分钟,秒 联合起来,就是2个时间的差距的字符串。
lacaltime和date做差
public long getMinutesDifference(Date date, LocalTime localTime) {// 将Date对象转换为LocalTimeLocalTime dateLocalTime = date.toInstant().atZone(ZoneId.systemDefault()).toLocalTime();// 计算时间差Duration duration = Duration.between(localTime, dateLocalTime);// 返回分钟差的绝对值return duration.toMinutes();}
这个案例是在考勤项目中遇到的,考勤时间是上午八点到下午20点,每天都如此,于是就用LocalTime记录的考勤规则。然后每天的实际打卡时间记录的是date,将这两个类型的数做减法,得到相差的分钟数目,根据正负,就可以得到是否迟到或者早退的情况。测试代码,如下。上面的这个函数,跟正常人的理解是一致的,如果前面的date是一个较晚的时间,返回的是正数,否则返回的是负数。一般LocalTime是考勤规则,Date是实际的打卡时间,做差,根据实际的业务去判断是否迟到早退。
public static void main(String[] args) {
// 示例用法Date date = new Date();LocalTime localTime = LocalTime.of(20, 10);long minutesDiff = getMinutesDifference(date, localTime);System.out.println("分钟差值: " + minutesDiff);}
sql语句,select子句当作where查询的条件
<!-- 根据上班时间 查询上下班的考勤规则 2h --><select id="selectRuleByTimeAndStaffId" resultMap="AttendanceStaffScheduleItemResult">select *from attendance_staff_schedule_itemwhere schedule_id IN (select schedule_idfrom attendance_staff_schedule_itemwhere staff_id = #{staffId}and attendance_time >= DATE_SUB(#{arriveTime},INTERVAL 2 HOUR)and attendance_time <= DATE_SUB(#{arriveTime},INTERVAL -2 HOUR)and access_type = 0)</select>
这个sql将select查询的结果当作子句,传入where中作为条件。不用写多个sql语句来实现这个功能了。主要记录的就是select语句也可以配合in当作where条件中的参数。
DATE_SUB()是一个MySQL函数,用于从指定的日期或时间中减去一定的时间间隔。传入的数据如果是正数,就是增加。