【修正版本】Golang 13位时间戳转time.Time

文章讨论了MySQL数据库中timestamp和datetime类型的差异,包括存储空间和时间范围。同时,介绍了时间戳在不同精度下的表示,并提供了Golang获取当前时间及转换时间戳的示例代码,强调了时间格式化和反格式化时精度的重要性。
摘要由CSDN通过智能技术生成

本文内容来自网络,做部分修订。

时间戳:时间戳是使用数字签名技术产生的数据,签名的对象包括了原始文件信息、签名参数、签名时间等信息。时间戳系统用来产生和管理时间戳,对签名对象进行数字签名产生时间戳,以证明原始文件在签名时间之前已经存在。

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而已。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值