项目场景:
背景:
开发中我们经常会遇到date时间格式的处理,尤其是将日期时分秒毫秒清零
问题描述
需要将当前时间的时分秒毫秒数进行清零,以匹配当天所有时间段的数据
方法一
java.util.Calendar设置
Calendar cal1 =Calendar.getInstance(newDate());
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 =newDate();// 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 =newSimpleDateFormat("yyyy-M-d");try{
twpDapLifeConsume.setDatatime(dateFormat.parse(dateFormat.format(newDate())));}catch(ParseException ignore){}
版权归原作者 FutureCanBeExpected 所有, 如有侵权,请联系我们删除。