后端开发笔记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函数,用于从指定的日期或时间中减去一定的时间间隔。传入的数据如果是正数,就是增加。

相关推荐
JAVA面经实录9171 小时前
Hibernate面试题库
数据库·oracle·hibernate
ZC跨境爬虫2 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
元气少女小圆丶2 小时前
SenseGlove Nova 2+Unity开发笔记1
笔记·学习·unity
迷枫7122 小时前
DM8 目录结构与常用排查入口梳理
服务器·数据库
李子琪。2 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星3 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒3 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
丷丩3 小时前
MapLibre GL JS第19课:实时更新要素
前端·javascript·gis·map·mapbox·maplibre gl js
Mr.Daozhi3 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
小程故事多_803 小时前
Claude Code自定义workflow skills用法
数据库·人工智能·智能体