后端开发笔记20240106

文章目录

写在前面

出来创业也一年多了,感觉这一年,后端的开发荒废了很多,都快不如专注做后端开发两三年的学弟学妹们了,逼着自己开了这个专栏,让自己坚持把每天开发的收获写一写。

时间相关的减法操作

两个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对象转换为LocalTime
        LocalTime 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_item
        where schedule_id IN (
            select schedule_id
            from attendance_staff_schedule_item
            where 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函数,用于从指定的日期或时间中减去一定的时间间隔。传入的数据如果是正数,就是增加。

相关推荐
果粒蹬i11 分钟前
生成式 AI 质量控制:幻觉抑制与 RLHF 对齐技术详解
前端·人工智能·easyui
马克学长13 分钟前
SSM学生综合考评系统b8vlm(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·学生综合考评系统·高校学生管理、
独自破碎E31 分钟前
MySQL中如何进行SQL调优?
数据库·sql·mysql
June bug44 分钟前
【实习笔记】客户端基础技术
笔记·macos·cocoa
laplace01231 小时前
第八章 agent记忆与检索 下
数据库·人工智能·笔记·agent·rag
MyselfO(∩_∩)O1 小时前
1148. 文章浏览 I
数据库
WordPress学习笔记1 小时前
解决Bootstrap下拉菜单一级链接无法点击的问题
前端·bootstrap·html
少云清1 小时前
【性能测试】10_JMeter _JMeter连接数据库(重点)
数据库·jmeter
程序员敲代码吗1 小时前
使用Python进行PDF文件的处理与操作
jvm·数据库·python
Never_Satisfied1 小时前
C#插值字符串中大括号表示方法
前端·c#