以前从来没关注过这个问题,今天使用阿里云的DTS时,需要一个参数就是时间戳,然后,使用java生成了一个,但是和示例给的时间戳明显位数不同,就很奇怪,这里做一些实验测试。
1.时间戳的区别
Unix时间戳是从1970年1月1日(UTC/GMT的午夜)开始所经过的秒数,不考虑闰秒。
但是Java
中很多获取时间戳的API
并不是获取到Unix
时间戳,而是获取到*从1970年1月1日(UTC/GMT的午夜)开始所经过的毫秒数***。以毫秒计算的时间戳下面统一称为时间戳。
2.java.util.Date提供的方法
@Test public void get(){ Date date = new Date(); long time = date.getTime(); log.info("=="+time); }
结果:
20:23:10.041 [main] INFO com.jun.prove.common.TimeStampUtils - ==1584966190036
sql:
select unix_timestamp(now());
发现:
几乎是一样的,一个是毫秒,一个是秒。
3.java.util.Calendar
@Test public void canlendar(){ //初始化Calendar对象 Calendar calendar=Calendar.getInstance(); //获取Calendar对象对应的时间戳 System.out.println(calendar.getTimeInMillis()); }
结果:
1584966409568
sql:
4.java.sql.Timestamp
public void timeStamp(){ //初始化Timestamp,需要注意构造方法的入参是一个时间戳 Timestamp timestamp=new Timestamp(System.currentTimeMillis()); //获取Timestamp对象对应的时间戳 System.out.println(timestamp.getTime()); }
5.JDK8中java.time.LocalDateTime
@Test public void get2() { //初始化时区对象,北京时间是UTC+8,所以入参为8 ZoneOffset zoneOffset = ZoneOffset.ofHours(8); //初始化LocalDateTime对象 LocalDateTime localDateTime = LocalDateTime.now(); //获取LocalDateTime对象对应时区的Unix时间戳 System.out.println(localDateTime.toEpochSecond(zoneOffset)); }
结果:1584966767
sql: