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

相关推荐
灵感__idea12 小时前
Hello 算法:“走一步看一步”的智慧
前端·javascript·算法
吴文周13 小时前
告别重复劳动:一套插件让 AI 替你写代码、修Bug、做测试、上生产
前端·后端·ai编程
Mh13 小时前
我决定写一个 3D 地球仪来记录下我要去的地方
前端·javascript·动效
yaoxin52112314 小时前
390. Java IO API - WatchDir 示例
java·前端·python
懒狗小前端14 小时前
做了一个 codex 的中文文档网站,做的不好可以随便喷
前端·后端
sunshine88514 小时前
财务RPA的深水区应用:超越自动化,迈向智能决策支持
数据库
efir OONA14 小时前
MySQL数据库误删恢复_mysql 数据 误删
数据库·mysql·adb
daanpdf15 小时前
新视野大学英语视听说教程2第四版听力音频原文及答案
笔记
zhangchaoxies15 小时前
如何在 Go 中安全复制接口指针所指向的值
jvm·数据库·python
. . . . .15 小时前
ref、useRef 和 forwardRef
前端·javascript·react.js