我试图在数据库中插入一个 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)
| 归档时间: |
|
| 查看次数: |
3534 次 |
| 最近记录: |