基本介绍
MySQL
数据库驱动用得最多的是这个第三方包:https://github.com/go-sql-driver/mysql ,在这个第三方包中有这么一个参数:
大概的意思是,当你提交的时间参数为time.Time
时,该参数用来转换参数时区的。当你在连接数据库时,该参数传递loc=Local
,那么该driver
将会自动将你提交的time.Time
参数转换为本地程序设置的时区,没有手动设置时,那么该时区为UTC
时区。那么我们来看两个例子。
转换示例
这里由于通过time.ParseInLocation
创建的time.Time
时间对象是+8
时区,和loc=Local
的时区一致,那么提交到数据库执行时不会被底层的driver
修改。
注意在写入数据中包含time.Time
参数时,也需要注意时区转换的问题。
示例2,不设置loc
参数
这里由于通过time.Parse
创建的time.Time
时间对象是UTC
时区,那么提交到数据库执行时将不会被底层的driver
修改。
注意在写入数据中包含time.Time
参数时,也需要注意时区转换的问题。
改进方案
也就是说,当你使用time.Time
对象作为时间参数时,无论如何你都会需要注意时区自动转换的问题。因此,为了避免这样的心智负担,防止大家踩坑,在保留对time.Time
参数支持的同时,ORM
增加了对gtime.Time
类型参数的支持,该类型不会涉及到时区转换困惑的问题。例如:
即,你传递什么时间参数,那么提交到数据库执行的也是同样的时间参数,不会执行任何的时区转换,免去了心智负担。
此外,还需要说明的是,gf
框架的默认情况下没有设置loc
参数。