mysql插入的时间莫名的加一秒
1、问题描述
我获取当天最大的时间:结果是当天的23:59:59秒
1 public static Date getDateWithMaxTime(Date date) { 2 Calendar calendar = Calendar.getInstance(); 3 calendar.setTime(date); 4 calendar.set(Calendar.HOUR_OF_DAY, 23); 5 calendar.set(Calendar.MINUTE, 59); 6 calendar.set(Calendar.SECOND, 59); 7 return calendar.getTime(); 8 }
但是插入数据库的时间多了1秒钟,变成第二天的00:00:00
2、解决办法
我把最后一位毫秒变为0 了,mysql(有些版本的)会对插入的时间的毫秒值大于500的进位操作,所以在此地设置毫秒值为0.
1 public static Date getDateWithMaxTime(Date date) { 2 Calendar calendar = Calendar.getInstance(); 3 calendar.setTime(date); 4 calendar.set(Calendar.HOUR_OF_DAY, 23); 5 calendar.set(Calendar.MINUTE, 59); 6 calendar.set(Calendar.SECOND, 59); 7 calendar.set(Calendar.MILLISECOND,0); //增加毫秒设置为0 8 return calendar.getTime(); 9 }
hello world!!!