本文内容来自网络,做部分修订。
时间戳:时间戳是使用数字签名技术产生的数据,签名的对象包括了原始文件信息、签名参数、签名时间等信息。时间戳系统用来产生和管理时间戳,对签名对象进行数字签名产生时间戳,以证明原始文件在签名时间之前已经存在。
mysql类型timestamp(时间戳)和datetime(时间)差别:
timestamp占用4个字节;
datetime占用8个字节;
timestamp范围1970-01-01 00:00:01.000000 到 2038-01-19 03:14:07.999999;
datetime是1000-01-01 00:00:00.000000 到 9999-12-31 23:59:59.999999;
时间戳格式:
10位数的时间戳是以 秒 为单位,如:1530027865
13位数的时间戳是以 毫秒 为单位, 如:1530027865231
19位数的时间戳是以 纳秒 为单位,如:1530027865231834600
Golang获取当前时间或时间戳
// string
time.Now().Format("2006-01-02 15:04:05")
// time.Time
time.Now()
// int64 时间戳,默认10位,单位:秒
time.Now().UnixNano()
13位时间戳转时间格式
func UnixToTime(e string) (datatime time.Time, err error) {
data, err := strconv.ParseInt(e, 10, 64)
datatime = time.Unix(data/1000, 0)
return
}
【修正版本】时间转13位时间戳
func TimeToUnix(e time.Time) int64 {
return e.UnixNano() / 1e6
}
很多文章写的是
func TimeToUnix(e time.Time) int64 {
timeUnix, _ := time.Parse("2006-01-02 15:04:05", e.Format("2006-01-02 15:04:05"))
return timeUnix.UnixNano() / 1e6
}
注意上面的格式化与反格式化操作会使精度丢失,没有了毫秒。即使出来的是13位的unix时间戳,那么结果最后三位也都是0而已。