背景:在一个老项目中,发现报表导出的日期,部分出现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