java代码中和mysql数据库中时间相差1秒问题?
mysql数据库的时间总是比代码中的时间多一秒。
@org.junit.Test public void ttt() throws InterruptedException { SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss:SSS"); for (int i = 0; i < 10; i++) { Thread.sleep(100); final Date date0 = new Date(); Date date1 = DateUtils.round(date0, Calendar.SECOND); Date date2 = DateUtils.ceiling(date0, Calendar.SECOND); Date date3 = DateUtils.truncate(date0, Calendar.SECOND); final Timestamp timestamp = Timestamp.valueOf( new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.SIMPLIFIED_CHINESE).format(date0) ); System.out.println("new Date() =============================================>"+ date0 + " " + df.format(date0)); System.out.println(" org.apache.commons:commons-lang3:3.8.1 .DateUtils.round " + date1+ " " + df.format(date1)); System.out.println(" org.apache.commons:commons-lang3:3.8.1 .DateUtils.ceiling " + date2+ " " + df.format(date2)); System.out.println(" org.apache.commons:commons-lang3:3.8.1 .DateUtils.truncate " + date3+ " " + df.format(date3)); //舍去毫秒 System.out.println("timestamp==================================================>"+timestamp+ " " + df.format(timestamp));//舍去毫秒 } }
可以更具上边代码自己测试,查看结果。
思路:时间如果毫秒多余500,存到mysql总是会多出一秒的时间。所以这个我们在代码中用到时间的时候。
时间格式化 SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
这样子拿到的时间就是去掉了毫秒的数据值,但是存到mysql中的时间是
Date date0 = new Date();
这个可是没有去掉毫秒的,所以数据库就给我们四舍五入了,导致我们数据库中的时间比代码中的时间多一秒。
所以为了获取到准确的时间,我们在使用时间的时候,就需要自己斟酌了。