这个问题由于大家问得比较多,因此单独开了一个章节详细介绍一下ORM
中的时区处理是怎么一回事。我们这里以MySQL
数据库为基础来介绍时区转换的事情,本地时区我们设定为+8时区,数据库时区也是+8时区。
黄冈网站建设公司创新互联建站,黄冈网站设计制作,有大型网站制作公司丰富经验。已为黄冈上千多家提供企业网站建设服务。企业网站搭建\成都外贸网站建设要多少钱,请找那个售后服务好的黄冈做网站的公司定做!
MySQL
数据库驱动用得最多的是这个第三方包:https://github.com/GO-sql-driver/mysql ,在这个第三方包中有这么一个参数:
大概的意思是,当你提交的时间参数为time.Time
时,该参数用来转换参数时区的。当你在连接数据库时,该参数传递loc=Local
,那么该driver
将会自动将你提交的time.Time
参数转换为本地程序设置的时区,没有手动设置时,那么该时区为UTC
时区。那么我们来看两个例子。
配置文件
[database]
link = "mysql:root:12345678@tcp(127.0.0.1:3306)/test?loc=Local"
代码示例
t1, _ := time.Parse("2006-01-02 15:04:05", "2020-10-27 10:00:00")
t2, _ := time.Parse("2006-01-02 15:04:05", "2020-10-27 11:00:00")
db.Model("user").Where("create_time>? and create_time", t1, t2).One()
// 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时区。
t1, _ := time.ParseInLocation("2006-01-02 15:04:05", "2020-10-27 10:00:00", time.Local)
t2, _ := time.ParseInLocation("2006-01-02 15:04:05", "2020-10-27 11:00:00", time.Local)
db.Model("user").Where("create_time>? and create_time", t1, t2).One()
// SELECT * FROM `user` WHERE create_time>'2020-10-27 10:00:00' AND create_time<'2020-10-27 11:00:00'
这里由于通过time.ParseInLocation
创建的time.Time
时间对象是+8时区,和loc=Local
的时区一致,那么提交到数据库执行时不会被底层的driver
修改。
注意在写入数据中包含time.Time
参数时,也需要注意时区转换的问题。
配置文件
[database]
link = "mysql:root:12345678@tcp(127.0.0.1:3306)/test"
代码示例
t1, _ := time.Parse("2006-01-02 15:04:05", "2020-10-27 10:00:00")
t2, _ := time.Parse("2006-01-02 15:04:05", "2020-10-27 11:00:00")
db.Model("user").Where("create_time>? and create_time", t1, t2).One()
// SELECT * FROM `user` WHERE create_time>'2020-10-27 10:00:00' AND create_time<'2020-10-27 11:00:00'
这里由于通过time.Parse
创建的time.Time
时间对象是UTC
时区,那么提交到数据库执行时将不会被底层的driver
修改。
t1, _ := time.ParseInLocation("2006-01-02 15:04:05", "2020-10-27 10:00:00", time.Local)
t2, _ := time.ParseInLocation("2006-01-02 15:04:05", "2020-10-27 11:00:00", time.Local)
db.Model("user").Where("create_time>? and create_time", t1, t2).One()
// 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
参数时,也需要注意时区转换的问题。
也就是说,当你使用time.Time
对象作为时间参数时,无论如何你都会需要注意时区自动转换的问题。因此,为了避免这样的心智负担,防止大家踩坑,在保留对time.Time
参数支持的同时,ORM
增加了对gtime.Time
类型参数的支持,该类型不会涉及到时区转换困惑的问题。例如:
t1 := gtime.New("2020-10-27 10:00:00")
t2 := gtime.New("2020-10-27 11:00:00")
db.Model("user").Where("create_time>? and create_time", t1, t2).One()
// SELECT * FROM `user` WHERE create_time>'2020-10-27 10:00:00' AND create_time<'2020-10-27 11:00:00'
即,你传递什么时间参数,那么提交到数据库执行的也是同样的时间参数,不会执行任何的时区转换,免去了心智负担。
这也是为什么GoFrame
框架cli
开发工具自动生成的model
代码文件中涉及到时间类型的属性均使用了*gtime.Time
类型而不是time.Time
的缘故。
此外,还需要说明的是,goframe
框架的ORM
默认情况下没有设置loc
参数,可以通过Timezone
参数配置。
当前题目:创新互联GoFrame教程:GoFrame数据库ORM-时区处理
分享链接:http://www.csdahua.cn/qtweb/news41/297191.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网