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

相关推荐
Python私教16 分钟前
GenericAgent PySide6 桌面应用深度解析:悬浮按钮 + 聊天面板的原生 Qt 方案
开发语言·数据库·qt
竹林81821 分钟前
wagmi v2 多链钱包切换:一个 Uniswap 仿盘项目让我踩了三天坑
前端·javascript
donecoding29 分钟前
Playwright MCP 页面捕获:Snapshot、截图、HTML 到底选哪个?
前端·ai编程·前端工程化
滕青山31 分钟前
在线PDF拆分工具核心JS实现
前端·javascript·vue.js
Smilezyl31 分钟前
一个独立开发者,靠一份 markdown 驱动 Claude Code, 用 20 天跑通 9 个包的 monorepo 工程
前端·人工智能·github
技术崽崽41 分钟前
不止有 Agent:Cursor 进阶使用技巧全解析
前端
byoass42 分钟前
企业云盘与设计软件深度集成:AutoCAD/Revit/SolidWorks插件开发与API集成实战
服务器·网络·数据库·安全·oracle·云计算
风骏时光牛马1 小时前
Pascal基础语法与控制台编程实战案例详解
前端
TeamDev1 小时前
JxBrowser 9.0.0 版本发布啦!
java·前端·混合应用·jxbrowser·浏览器控件·跨平台渲染·原声输入
freexyn1 小时前
Matlab自学笔记七十六:表达式的展开、因式分解、化简、合并同类项
笔记·算法·matlab