hutool的bug之 DateUtil.endOfDay(DateUtil.date())

hutool  工具类DateUtil

使用时谨慎

DateUtil.endOfDay 得到的时间保存到数据时会增加一秒

首先比较下时间的long值:

这样就很明显的看出来,hutool工具类的date是毫秒位多了.999,保存到mysql 的时候,MySQL数据库对于毫秒大于500的数据进行进位,这样就导致了得到的时间到mysql时会增加一秒。


网络上的解决方案:
https://www.cnblogs.com/fswhq/p/mysql_1.html
代码如下:

public static Date getEndOfDay(Date date) {
        Calendar calendarEnd = Calendar.getInstance();
        calendarEnd.setTime(date);
        calendarEnd.set(Calendar.HOUR_OF_DAY, 23);
        calendarEnd.set(Calendar.MINUTE, 59);
        calendarEnd.set(Calendar.SECOND, 59);
        calendarEnd.set(Calendar.MILLISECOND, 0); // 这一句比较关键
        return calendarEnd.getTime();
    }

相关推荐

  1. Hutool

    2023-12-08 03:46:03       12 阅读
  2. nicetool--替代hutool和fastjson工具库

    2023-12-08 03:46:03       21 阅读
  3. Hutool工具包中Validator类数据校验

    2023-12-08 03:46:03       17 阅读
  4. 一些意外bug

    2023-12-08 03:46:03       40 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-08 03:46:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-08 03:46:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-08 03:46:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-08 03:46:03       18 阅读

热门阅读

  1. 如何使用PDCA循环来提升软件产品的质量

    2023-12-08 03:46:03       34 阅读
  2. 股票怎么加杠杆买入

    2023-12-08 03:46:03       32 阅读
  3. Web3之L2 ZK-Rollup 方案-StarkNet

    2023-12-08 03:46:03       38 阅读
  4. 存储过程与视图

    2023-12-08 03:46:03       37 阅读
  5. 【UGUI】实现UGUI背包系统的六个主要交互功能

    2023-12-08 03:46:03       39 阅读
  6. deepin v20 在线安装docker

    2023-12-08 03:46:03       39 阅读
  7. vue中字典的使用

    2023-12-08 03:46:03       38 阅读