背景:在一个老项目中,发现报表导出的日期,部分出现12小时时差问题,数据库中存储的时间为2021-07-22 00:19:17,导出的报表时间为2021-07-22 12:19:17 。
经过排查发现是时间格式导致出现12小时时差的问题。
时间格式化patter:
yyyy-MM-dd HH:mm:ss //24小时制
yyyy-MM-dd hh:mm:ss //12小时制
如果用12小时制去格式化时间可能会出现背景中描述的12小时时差问题
//将指定日期字符串转换为日期
DateFormat dateFormat2 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date date = dateFormat2.parse("2021-07-22 00:19:17");
//将日期转换为字符串
dateFormat.format(date);
//==============================
//date不同时间格式的输出
Date nowDate = new Date();
SimpleDateFormat twelveFormat = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");//12小时制
System.out.println(twelveFormat.format(nowDate)); //输出2021-07-22 02:11:39
SimpleDateFormat twentyFourFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//24小时制
System.out.println(twentyFourFormat.format(nowDate)); //输出2021-07-22 14:11:39
//java8 LocalDateTime
LocalDateTime currentTime = LocalDateTime.now()
DateTimeFormatter dtf = DateTimeFormatter.ofPattern("yyyy-MM-dd hh:mm:ss");
System.out.println(dtf.format(currentTime));
//输出2021-07-22 02:11:39
DateTimeFormatter dtf2 = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
System.out.println(dtf2.format(currentTime));
//输出2021-07-22 14:11:39
Java时间格式化导致的12小时时差问题解析

本文介绍了在老项目中遇到的一个日期导出时差问题,原因是时间格式设置不当。当使用12小时制的格式化模式(yyyy-MM-ddhh:mm:ss)处理24小时制的日期(如2021-07-2200:19:17)时,会出现12小时的时差。通过示例代码展示了如何正确地进行时间格式转换,避免此类问题的发生。
6147

被折叠的 条评论
为什么被折叠?



