基本介绍

MySQL数据库驱动用得最多的是这个第三方包:https://github.com/go-sql-driver/mysql ,在这个第三方包中有这么一个参数:

大概的意思是,当你提交的时间参数为time.Time时,该参数用来转换参数时区的。当你在连接数据库时,该参数传递loc=Local,那么该driver将会自动将你提交的time.Time参数转换为本地程序设置的时区,没有手动设置时,那么该时区为UTC时区。那么我们来看两个例子。

转换示例

配置文件

  1. t2, _ := time.Parse("2006-01-02 15:04:05", "2020-10-27 11:00:00")
  2. // SELECT * FROM `user` WHERE create_time>'2020-10-27 18:00:00' AND create_time<'2020-10-27 19:00:00'

这里由于通过time.Parse创建的time.Time时间对象是UTC时区,那么提交到数据库执行时将会被底层的driver修改为+8时区。

这里由于通过time.ParseInLocation创建的time.Time时间对象是+8时区,和loc=Local的时区一致,那么提交到数据库执行时不会被底层的driver修改。

注意在写入数据中包含time.Time参数时,也需要注意时区转换的问题。

示例2,不设置loc参数

配置文件

  1. database:

这里由于通过time.Parse创建的time.Time时间对象是UTC时区,那么提交到数据库执行时将不会被底层的driver修改。

  1. t1, _ := time.ParseInLocation("2006-01-02 15:04:05", "2020-10-27 10:00:00", time.Local)
  2. t2, _ := time.ParseInLocation("2006-01-02 15:04:05", "2020-10-27 11:00:00", time.Local)
  3. db.Model("user").Where("create_time>? and create_time<?", t1, t2).One()
  4. // SELECT * FROM `user` WHERE create_time>'2020-10-27 02:00:00' AND create_time<'2020-10-27 03:00:00'

这里由于通过time.ParseInLocation创建的time.Time时间对象是+8时区,那么提交到数据库执行时会被底层的driver修改为UTC时区。

注意在写入数据中包含time.Time参数时,也需要注意时区转换的问题。

改进建议

建议统一加上配置,例如:loc=Local&parseTime=true。以下是一个可供参考的配置: