Golang 插入 time.Now 到数据库中被转移到 UTC

Fir*_*nis 7 go go-gorm

我试图在数据库中插入一个 time.Now() 字段,但不断发生的是时间向前移动到 UTC。我理解这个想法是在呈现给用户时始终转换为本地时间。问题是我继承了这个系统,目前还很容易改变。

有小费吗?我看到您可以在 DSN 中设置 loc,但它没有解释将其更改为什么,也没有解释其实际效果,因此我很感激那里的信息。

编辑:一些信息,它是 MySQL DB,使用 go-mysql 1.1 和 go 1.6.3。正在将数据插入到 DATETIME 字段中。

插入时数据不正确。GORM Debug 显示一次,MySQL 查询记录器显示它向前移动。

我发现问题在于 go-mysql 驱动程序自动将时间转换为 UTC,这可以使用 DSN 中的 loc 参数进行更改。然而,这也改变了时间的返回方式。

要解决此问题,请将 loc=Local 添加到您的 DSN。

小智 5

这是我用来始终存储本地时间的方式。即使您的 VPS 位于另一个时区国家,也能正常工作:

db, err = gorm.Open("mysql", "root:@tcp(localhost:3306)/mydatabase?charset=utf8&parseTime=True&loc=America%2FSao_Paulo")
Run Code Online (Sandbox Code Playgroud)


sop*_*ope -3

因为 golang 解析中的时间将使用 UTC