今天在测试一个前台项目的时候,发现页面上的时间和数据库中的时间戳有出入,大多是1秒的出入。我是使用网上的时间戳转换工具转换的,一开始是怀疑网上的工具不靠谱,就写了个java,自己转一下,主要是时间戳与yyyy-MM-dd时间格式的互转,贴一下代码
package org.time;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class TimeUtil {
/*
* 时间戳转换为yyyy-MM-dd格式/
*/
public static void StampToTime() {
final long nowTime = System.currentTimeMillis();//获取系统当前时间
long stamp = 1535091681L;//设置你的时间
final Date date = new Date(stamp);//新建一个时间对象
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//你要转换成的时间格式,大小写不要变
final String yourtime = sdf.format(date);//转换你的时间
final String nowtime = sdf.format(nowTime);
System.out.println("当前系统时间:"+nowtime+"\n"+stamp+" 转换后是:"+yourtime);//打印出你转换后的时间
}
/*
*yyyy-MM-dd格式转换为时间戳 /
*/
public void TimeToStamp() throws Exception {
final SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String mydate = "2018-09-08 18:09:09";
final Date datetime = sdf.parse(mydate);//将你的日期转换为时间戳
final long time = datetime.getTime();
System.out.println(mydate+"转换后是:"+time);
}
}
package org.time;
public class TimeMain {
public static void main(String[] args) throws Exception {
/*
* 时间戳转化为 yyyy-MM-dd格式/
*/
TimeUtil.StampToTime();//static静态类可以直接使用类名.方法
/*
* yyyy-MM-dd格式转换为时间戳
*/
final TimeUtil ts = new TimeUtil();
ts.TimeToStamp();
}
}
结果发现,我自己转换后的时间与网上的时间戳转换工具的结果一致。。
再研究了下,发现系统使用的是mysql的时间转换函数而不是java,二者在精度上有一点点的区别,倒是无可厚非。感兴趣的同学可以研究下二者的区别,后续再发表mysql时间转换函数相关的文章。