Go语言MySQL时区问题

最近由于我要统一技术栈,因此把原本使用SQLite做存储的数据全部迁移到MySQL。博客也是。不过当我检查数据库时,发现时间和 我产生数据的时间相差8小时。

首先检查机器的时间:

$ date
Thu 14 Nov 2019 11:13:59 AM CST

检查MySQL的时间:

> select now();
+---------------------+
| now()               |
+---------------------+
| 2019-11-14 11:14:42 |
+---------------------+
1 row in set (0.000 sec)

检查Go的时间:

package main

import (
	"fmt"
	"time"
)

func main() {
	fmt.Printf("now: %s\n", time.Now())
}

执行:

$ go run main.go 
now: 2019-11-14 11:16:44.277801507 +0800 CST m=+0.000070270

检查数据时间:

> select * from issue order by id desc limit 1;
+-----+---------------------+---------------------+------------+------------+----------------------------------+
| id  | created_at          | updated_at          | deleted_at | content    | url                              |
+-----+---------------------+---------------------+------------+------------+----------------------------------+
| 285 | 2019-11-14 01:54:53 | 2019-11-14 01:54:57 | NULL       | htop详解   | https://peteris.rocks/blog/htop/ |
+-----+---------------------+---------------------+------------+------------+----------------------------------+
1 row in set (0.000 sec)

1点?这是不可能的。


综合上面的检查结果,我们知道:

  • Go的程序输出的时间没有问题
  • 系统的时间也没有问题
  • 数据库的时间也没有问题
  • 本地开发机器的时间也没有问题

那么问题会在哪里呢?我的经验告诉我,可能是数据库驱动的锅。检查一下配置:

SQLX_URL="user:abcdefg@(localhost:3306)/blog?parseTime=true"

发现我之前加了 parseTime=true,如果不加的话,就无法让驱动把MySQL的 DATETIME 类型和Go的 time.Time 互转。于是查了一下 文档,发现需要用loc来指定时区。我选择和机器一致,因此改成下面即可:

SQLX_URL="user:abcdefg@(localhost:3306)/blog?parseTime=true&loc=Local"

注:网友提示,使用loc=Local使用本地机器可能有这么一个坑:多个机器之间不在同一个时区,如果有这种需求,那么就 需要统一时区,使用例如 loc=Asia%2FShanghai 。


参考资料:


微信公众号
关注公众号,获得及时更新

更多文章
  • 读《远见-如何规划职业生涯3大阶段》
  • 后端工程师学前端(五): SASS
  • 后端工程师学前端(四): CSS进阶(盒子模型)
  • 读《投资中最简单的事》
  • 后端工程师学前端(三): CSS进阶(特指度、单位和字体族)
  • 后端工程师学前端(二): CSS基础知识(规则与选择器)
  • Swift语法笔记
  • 后端工程师学前端(一): HTML
  • 读《管理的实践》
  • frp 源码阅读与分析(二):TCP内网穿透的实现
  • 五天不用微信 - 爽得很
  • frp 源码阅读与分析(一):流程和概念
  • 学习frp源码之简洁的在两个connection之间转发流量
  • 自己动手写一个反向代理
  • 读《债务危机》