当前位置: 首页 > article >正文

【高效开发工具系列】Hutool DateUtil工具类

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。
img

  • 推荐:kwan 的首页,持续学习,不断总结,共同进步,活到老学到老
  • 导航
    • 檀越剑指大厂系列:全面总结 java 核心技术点,如集合,jvm,并发编程 redis,kafka,Spring,微服务,Netty 等
    • 常用开发工具系列:罗列常用的开发工具,如 IDEA,Mac,Alfred,electerm,Git,typora,apifox 等
    • 数据库系列:详细总结了常用数据库 mysql 技术点,以及工作中遇到的 mysql 问题等
    • 懒人运维系列:总结好用的命令,解放双手不香吗?能用一个命令完成绝不用两个操作
    • 数据结构与算法系列:总结数据结构和算法,不同类型针对性训练,提升编程思维,剑指大厂

非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。💝💝💝 ✨✨ 欢迎订阅本专栏 ✨✨

博客目录

    • 一.基本介绍
      • 1.Hutool DateUtil 优点
      • 2.注意事项
    • 二.实战案例
      • 1.获取前七天
      • 2.时间段
      • 3.日期最小值
      • 4.日期最大值
      • 5.日期范围查询
      • 6.每一天概览

一.基本介绍

1.Hutool DateUtil 优点

Hutool 是一个 Java 工具包,提供了丰富的工具方法,用于简化 Java 开发过程中的常见任务。DateUtil 是 Hutool 中的日期工具类,它具有以下优点:

  1. 简单易用:DateUtil 提供了大量的静态方法,可以方便地进行日期的格式化、解析、比较、计算等操作,使用起来非常简单。
  2. 功能丰富:DateUtil 支持多种日期格式的解析和格式化,可以处理常见的日期操作,比如日期比较、日期计算、日期加减、日期格式化等。
  3. 高效性能:Hutool 的设计注重性能优化,DateUtil 的方法经过优化,执行效率高,可以提高应用程序的性能。
  4. 可扩展性:Hutool 提供了丰富的工具类和接口,可以根据需求自定义扩展,满足不同开发场景的需求。

Hutool 的 DateUtil 是一个功能强大、简单易用、高性能的日期工具类,可以方便地处理日期相关的操作。

2.注意事项

对于 hutool 的 DateUtil,需要注意以下事项:

  1. 引入 hutool 包:在使用 DateUtil 之前,需要先引入 hutool 的相关包,可以通过 Maven 或者 Gradle 等方式进行引入。
  2. 日期格式的正确性:在使用 DateUtil 进行日期的解析和格式化时,需要确保日期格式的正确性,否则可能会导致解析失败或者格式化结果不符合预期。
  3. 时区的设置:如果涉及到时区的问题,需要注意在使用 DateUtil 之前,设置好正确的时区,以避免日期计算和转换时出现错误。
  4. 线程安全性:hutool 的 DateUtil 是线程安全的,可以在多线程环境下使用,无需额外的同步处理。

二.实战案例

1.获取前七天

  • 使用 DateUtil 工具类进行加减
  • 可以直接获取昨天的日期
  • 昨天以及昨天之前的 7 天的日期
public static void main(String[] args) {
    List<String> dates = new ArrayList<>();
    final DateTime yesterdayDate = DateUtil.yesterday();
    final String yesterday = DateUtil.formatDate(yesterdayDate);
    dates.add(yesterday);
    for (int i = 1; i < 7; i++) {
        final DateTime dateTime = DateUtil.offsetDay(yesterdayDate, -i);
        dates.add(DateUtil.formatDate(dateTime));
    }
    for (String date : dates) {
        System.out.println(date);
    }
}

2.时间段

  • 用到了 DateUtil 工具包
  • 可以获取天的开始年月日时分秒
  • 可以在这个时间的基础上进行加减
@Override
public List<CsdnRedPackage> updateFor4Days() {
    QueryWrapper<CsdnRedPackage> wrapper = new QueryWrapper<>();
    wrapper.eq("is_delete", 0);
    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
    DateTime startOfDay = DateUtil.beginOfDay(DateUtil.date());
    String endFormattedDate = sdf.format(startOfDay);
    wrapper.le("create_time", endFormattedDate);
    final Date dateTime = DateUtil.offsetDay(startOfDay, -3);
    String startFormattedDate = sdf.format(dateTime);
    wrapper.ge("create_time", startFormattedDate);
    return this.list(wrapper);
}

3.日期最小值

最小值是加入一个比较器,然后 get 获取比较后的值

final Date min = content.stream().min(Comparator.comparing(x -> x.getTripletDate())).get().getTripletDate();
// 创建SimpleDateFormat对象,指定日期格式
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
// 使用format方法将Date对象转换为字符串
String minStr = dateFormat.format(min);

4.日期最大值

最大值是加入一个比较器,然后 get 获取比较后的值

final Date max = content.stream().max(Comparator.comparing(x -> x.getTripletDate())).get().getTripletDate();
// 创建SimpleDateFormat对象,指定日期格式
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
// 使用format方法将Date对象转换为字符串
String maxStr = dateFormat.format(max);

5.日期范围查询

  • 已知开始日期和结束日期,使用 mybatis-plus 查询范围数据
  • 获取指定格式的日期数据,不然查询会有差异
final Date startDate = query.getStartDate();
final Date endDate = query.getEndDate();
QueryWrapper<CsdnTripletDayInfo> wrapper = new QueryWrapper<>();
wrapper.eq("is_delete", 0);
if (Objects.nonNull(startDate)) {
    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
    String startFormattedDate = sdf.format(startDate);
    wrapper.ge("triplet_date", startFormattedDate);
}
if (Objects.nonNull(endDate)) {
    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
    String endFormattedDate = sdf.format(endDate);
    wrapper.le("triplet_date", endFormattedDate);
}

6.每一天概览

  • 已知最小日期和最大日期,求每一天的总金额,总个数,丢单个数
  • 注意日期格式化
  • 注意带条件的求和 sum
  • 注意特殊字符的转义
<select id="dayRedPackage" resultType="com.kwan.springbootkwan.entity.dto.CsdnDayRedPackageDTO">
    SELECT DATE_FORMAT(create_time, '%Y-%m-%d')               AS redPackageDate
         , SUM(my_amount)                                     AS myAmount
         , COUNT(1)                                           AS redPackageCount
         , SUM(if(msg = 'completed' AND my_amount = 0, 1, 0)) AS loseRedPackageCount
    FROM csdn_red_package
    WHERE 1 = 1
      AND DATE_FORMAT(create_time
              , '%Y-%m-%d') <![CDATA[>= #{min}]]>
      AND DATE_FORMAT(create_time
              , '%Y-%m-%d') <![CDATA[<= #{max}
    ]]>
    GROUP BY redPackageDate
    ORDER BY redPackageDate
</select>

觉得有用的话点个赞 👍🏻 呗。
❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄

💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍

🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

img


http://www.kler.cn/a/152691.html

相关文章:

  • ARM安全架构——为复杂软件提供保护
  • 设计模式:观察者模式
  • es6之class类(未完成)
  • K8s Docker实践三
  • Python开发运维:PyMongo 连接操作 MongoDB
  • 【Openstack Train安装】十二、Cinder安装
  • 力扣每日一题(2023-11-30)
  • drool 7 multiThread 测试
  • java分布式锁分布式锁
  • 鉴源论坛 · 观擎丨民机机载软件的配置管理
  • 【Android MediaCodec 将音频转换为 pcm 格式】
  • ModuleNotFoundError: No module named ‘mdtex2html‘ module已经安装还是报错,怎么办?
  • 利用python实现文件压缩打包的功能
  • 国际上有哪些比较出名的VOIP供应商
  • 计算两个经纬度之间的实际距离(Haversine公式)----c++
  • Python语言学习笔记之七(JOSN应用)
  • conda和pip常用命令整理
  • css加载会造成阻塞吗??
  • Linux 系统启动过程
  • Git常用命令#更改用户名