时区是指地球上的一个地理区域,它们按照标准时间来计算,并且每个时区都有自己的标准时间。数据库中的时区是用来表示特定地理位置的时间,这些位置可能是全球性的,也可能是局部性的。
数据库中使用时区有很多好处,首先,它可以帮助我们将不同地理位置的数据进行正确的对比和分析。例如,如果我们要分析一个全球性的市场营销趋势,我们可以使用不同地理位置的数据来进行分析。此外,使用时区也可以帮助我们将不同地理位置之间的事件整合到一起。例如,如果我们要监测一个全球性事件(例如天气情况、金融市场波动、新闻事件等),我们可以使用不同地理位置上的数据来进行监测。
SELECT * FROM table_name WHERE time_zone = 'UTC';
此外,使用数据库中的时区也可以帮助我们避免因为不同地理位置之间存在时差而对数据造成影响。例如:当我们要将一个国家数据库中存储的信息传递到另一个国家数据库中去时;当我们要将一个国家數 據庫中存儲 的信 息 合并 到 另 一 個 國 內 數 據 庫 中 時 ; 都 需 要 考 慎 时 差 的 關 係 。 这 时 , 我 们 可 以 通 过 获 取 相 关 时 川 的 信 息 ( 例 如 UTC ) ; 然后根据UTC来获得相应国家數 據庫中存儲 的信 息 ; 最后再根據需要將所有信 息 进衊 處 理 ; 最 終 都 能 夠 有 效 的 避免 咱 于 不 吝 的 天氣情况、金螊市場波動、断章事面耳相就影響耳數銭造成影響。
这个问题由于大家问得比较多,因此单独开了一个章节详细介绍一下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
参数配置。
gdb的数据记录结果(Value)支持非常灵活的类型转换,并内置支持常用的数十种数据类型的转换。Value类型是*gvar.V...
模板引擎特点简单、易用、强大;支持多模板目录搜索;支持layout模板设计;支持模板视图对象单例模式;与配置管理模块原生集...
生成值的汇总的另一个办法是为 QuerySet 的每一个对象生成独立汇总。比如,如果你想检索书籍列表,你可能想知道每一本书有多...
为什么 Django 使用自动提交在 SQL 规范中,每一个 SQL 查询会启动事务,除非一个事务已经处于活动状态。然后必须显式地提交或回...
WebSecurity - IsCurrentUser()WebSecurity 对象定义 IsCurrentUser() 方法把提供的用户名与已登录用户的用户名进行比较。C# 和 ...
WebSecurity 属性 - IsAuthenticatedWebSecurity 对象定义 IsAuthenticated 属性是一个布尔值,指示当前用户是否已通过身份验证...
ASP.NET TableRow HorizontalAlign 属性 TableRow 控件定义和用法 HorizontalAlign 属性用于设置或返回 TableRow 控件中内容的水...