项目场景:
背景:
开发中我们经常会遇到date时间格式的处理,尤其是将日期时分秒毫秒清零
问题描述
需要将当前时间的时分秒毫秒数进行清零,以匹配当天所有时间段的数据
方法一 java.util.Calendar设置
Calendar cal1 = Calendar.getInstance(new Date());cal1.setTime(now);// 将时分秒,毫秒域清零cal1.set(Calendar.HOUR_OF_DAY, 0);cal1.set(Calendar.MINUTE, 0);cal1.set(Calendar.SECOND, 0);cal1.set(Calendar.MILLISECOND, 0);System.out.println(cal1.getTime());
方法二 java.time.LocalDate转换
java8提供了一个新的类LocalDate,是一个不包含时区,ISO-8601 格式的日期类(比如 “2016-12-28”)
LocalDate对象是个只读取的(immutable class),java.util.Date可以转换为LocalDate
java.sql.Date是java.util.Date的子类,是为了配合SQL DATE而设置的数据类型
java.sql.Date只包含年月日信息,时分秒毫秒都会清零。格式类似:YYYY-MM-DD。
在java8中LocalDate可以转换成java.sql.Date
这两者一结合,也就可以将Date转换为时分秒清零0的对象,而且代码更简洁,一行就能搞定。
Date nowDate = new Date();// java.util.Date -> java.time.LocalDateLocalDate localDate=nowDate.toInstant().atZone(ZoneId.systemDefault()).toLocalDate();// java.time.LocalDate -> java.sql.DateDate newDate=java.sql.Date.valueOf(localDate);System.out.println(nowDate);
方法三 java.text.DecimalFormat
这个方法适合在没有三方参数接入的情况下,可以将异常在编译转运行时忽略掉
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-M-d");try { twpDapLifeConsume.setDatatime(dateFormat.parse(dateFormat.format(new Date()))); } catch (ParseException ignore) { }
来源地址:https://blog.csdn.net/weixin_45995287/article/details/128298852