电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL timestamp與時區(qū)問題的解決

瀏覽:43日期:2023-08-28 20:27:10
目錄MySQL 用什么類型存日期時間?JDBC 驅(qū)動和 MySQL 的時區(qū)問題MySQL ClientMySQL Servertimestamp 類型與時區(qū)的影響總結(jié)參考文獻

新項目可能存在國際化的問題,所以花了點時間了解了下 MySQL 和 JDBC 驅(qū)動相關(guān)的時間問題??戳撕枚嗥┛桶l(fā)現(xiàn),不少人理解的都是錯誤的,所以結(jié)合官方的文檔,重新梳理了一下。

大家都知道在 MySQL 中有兩個專門用來存取日期時間的類型,timestamp 和 datetime。大家總是說 datetime 不包含時區(qū)信息,timestamp 存的 utc 時間戳更適合國際化場景下的本地時間轉(zhuǎn)換。經(jīng)過了解,上述說法對,但不完全對。

版本信息:

MySQL5.7mysql-connector-java 8.0.31MySQL 用什么類型存日期時間?

目前可以存日期時間的數(shù)據(jù)類型主要分兩類:

bigint:直接將 utc 時間戳存到 int 類型的字段中。后期根據(jù)用戶本地時區(qū)進行轉(zhuǎn)換。日期時間類型:timestamp:MySQL 官方定義的時間戳,內(nèi)部使用 utc 時間戳存儲,但查詢時返回的結(jié)果會隨著 session time_zone 的變化而變化。datetime:只存日期時間的值,不包含時區(qū)信息。

那么我們應(yīng)該選擇哪個?先說結(jié)論在分析,根據(jù)需求選 bigint 或 datetime。

類型優(yōu)點缺點bigint1. 直觀,不需要考慮時區(qū)2. 國際化場景直接根據(jù)本地時區(qū)轉(zhuǎn)化3. 存儲和查詢效率高1. 數(shù)據(jù)庫直接查看時可讀性差,需要轉(zhuǎn)化timestamp無1. 查詢結(jié)果收到 session time_zone 的影響,容易出錯2. 最大時間為 2038 年datetime1. 可讀性好2. MySQL 自帶各種操作函數(shù),便于查詢3. 存儲日期范圍大,到 9999 年1. 存儲空間略大2. 查詢效率較前兩者低

所以在我看來,如果是后臺管理類的系統(tǒng),更適合使用 datetime,因為對性能要求沒那么高,并且查詢方便;其他的可以考慮 bigint。

其中最不建議使用的是 timestamp,因為這個會隨著 session time_zone 的變化而變化的,如果開發(fā)者對時區(qū)理解不深,當服務(wù)器或、MySQL 或者 JVM 時區(qū)發(fā)生變化時,很容易出現(xiàn)問題。

JDBC 驅(qū)動和 MySQL 的時區(qū)問題

剛剛講了 MySQL 的 timestamp 類型的查詢結(jié)果會受到 session time_zone 的變化而變化,那么這節(jié)我們就來講講時區(qū)的問題。

那么從 Springboot Application 到 MySQL,哪些地方存在時區(qū)的配置呢?自然是通信的兩端,MySQL 服務(wù)端和 MySQL 客戶端。

MySQL Client

這里的 Client 是一個籠統(tǒng)的概念,涉及 client 所在機器 os 的時區(qū)、對應(yīng)應(yīng)用程序的時區(qū)(eg: Java 應(yīng)用就是 JVM 時區(qū))、JDBC 驅(qū)動的時區(qū)。

機器 OS 時區(qū)root@T630-03:/# cat /etc/timezoneAsia/Shanghairoot@T630-03:/# date2023 年 06 月 21 日 星期三 11:20:28 CST

OS 時區(qū)影響的是 OS 自身的日期時間命令結(jié)果的返回,同時還是影響部分軟件,因為有些軟件會默認使用 OS 時區(qū)作為軟件時區(qū)。

應(yīng)用程序時區(qū)

這里我們 Spring Boot 應(yīng)用程序為例,對應(yīng)的就是 JVM 時區(qū),它默認使用的系統(tǒng)時區(qū),可通過輸出 ZoneId.*systemDefault*() 來查看。可通過 TimeZone.setDefault(TimeZone.getTimeZone("America/New_York")); 來配置。主要涉及在 Java 中操作日期和時間的相關(guān)類。比如 LocalDateTime.now() ,假設(shè)北京時間為 20:00,如果將 TimeZone 設(shè)置為 Asia/Tokyo,則會返回 21:00。

JDBC 驅(qū)動時區(qū)

在 Springboot 應(yīng)用程序中,我們通過 JDBC 驅(qū)動來連接到數(shù)據(jù)庫,在連接的過程中,我們需要配置 jdbcUrl 來指定 JDBC 時區(qū)。

在 8.0 的驅(qū)動中,是通過配置以下字段指定的:

這兩個參數(shù)指定了,通過 JDBC 驅(qū)動連接到 MySQL 的 session time_zone 為 Asia/Shanghai。那么通過 JDBC 驅(qū)動去調(diào)用 SQL 中日期時間相關(guān)的方法都會以此時區(qū)為準。

connectionTimeZone=Asia/ShanghaiforceConnectionTimeZoneToSession=trueMySQL Server

這里的 Server 指的是數(shù)據(jù)庫,涉及數(shù)據(jù)庫所在機器 os 的時區(qū)、MySQL 的時區(qū)。

機器 OS 時區(qū)

同上,但 MySQL 默認使用的是 OS 時區(qū)

MySQL 會話時區(qū)mysql> show global variables like '%time_zone%';+------------------+--------+| Variable_name | Value |+------------------+--------+| system_time_zone | CST || time_zone| SYSTEM |+------------------+--------+2 rows in set (0.00 sec)

MySQL 有一個默認的時區(qū)配置,如上,是使用 OS 時區(qū)作為 MySQL 默認時區(qū)的。MySQL 其實本身是沒有所謂的時區(qū)的,我們所說的都是它的 session time_zone,具體的:

MySQL 存在一個默認時區(qū),一般是 SYSTEM??赏ㄟ^配置文件或 SQL 進行修改。Client 連接到 MySQL 時若不指定 session time_zone,默認使用 MySQL Server 的時區(qū)。也可通過 JdbcUrl 在連接的時候指定或通過 SET time_zone ='UTC'; 指定。Client 在指定了 session time_zone 后,所有的日期時間查詢均會按照所在時區(qū)返回結(jié)果。timestamp 類型與時區(qū)的影響

timestamp 在 MySQL 中其實保存就是 UTC 時間戳,當 Client 配置不同的會話時區(qū)后,會進行轉(zhuǎn)換顯示。

下面舉幾個最直觀的例子。

表 time_test,有一個 timestamp 類型的字段 client_time。

直接在 MySQL 控制臺操作

SET time_zone = 'Asia/Shanghai';# 2023-06-20 08:00:00insert into time_test(client_time) values (current_timestamp());select * from time_test ;SET time_zone = 'UTC';# 2023-06-20 00:00:00select * from time_test ;# 2023-06-20 00:01:00insert into time_test(client_time) values (current_timestamp());select * from time_test ;SET time_zone = 'Asia/Shanghai';# 2023-06-20 08:01:00select * from time_test ;

? 結(jié)果應(yīng)該很好理解。按照當前時區(qū)插入數(shù)據(jù)后,查詢結(jié)果是當前時區(qū)的日期,更換時區(qū)后,會進行相應(yīng)的偏移,MySQL 會自動進行轉(zhuǎn)換。

通過 JDBC 驅(qū)動操作

? 通過 SpringBoot 調(diào)用 JDBC 驅(qū)動查詢,雖然中間涉及到了多個時區(qū)概念,但其實轉(zhuǎn)換過程也很簡單。

JVM 時區(qū)JVM 日期(假設(shè)是 LocalDateTime.now() 返回)JDBC 驅(qū)動時區(qū)插入后返回的查詢結(jié)果Asia/Shanghai2023-06-20 08:00:00Asia/Shanghai2023-06-20 08:00:00Asia/Shanghai2023-06-20 08:00:00UTC2023-06-20 00:00:00Asia/Tokyo2023-06-20 09:00:00Asia/Shanghai2023-06-20 08:00:00Asia/Tokyo2023-06-20 09:00:00UTC2023-06-20 01:00:00

說白了,只與 JDBC 驅(qū)動的時區(qū)有關(guān)。

當我們做國際化項目時,只需要保持 JVM 時區(qū)和 JDBC 驅(qū)動時區(qū)一致,均為 Asia/Shanghai。其他用戶,只需要根據(jù)設(shè)置的本地時區(qū)進行轉(zhuǎn)換即可。

總結(jié)

一番了解下來,最易用的其實還是bigint和datetime這兩個時區(qū)無關(guān)的類型,時區(qū)相關(guān)的操作直接由我們自己控制最理想。并且也沒有timestamp的時間限制。總結(jié)下:

優(yōu)先使用bigint和datetime,國際化在代碼層面做。要使用timestamp,需要了解清楚各種時區(qū)的信息并做好配置。防止因為機器時區(qū)改變、數(shù)據(jù)庫時區(qū)改變而影響查詢的結(jié)果。參考文獻6.3.11 Datetime types processing6.6.1 Preserving Time InstantsSupport for Date-Time Types in Connector/J 8.0

到此這篇關(guān)于MySQL timestamp與時區(qū)問題的解決的文章就介紹到這了,更多相關(guān)MySQL timestamp與時區(qū)內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

相關(guān)文章:
主站蜘蛛池模板: 插针变压器-家用电器变压器-工业空调变压器-CD型电抗器-余姚市中驰电器有限公司 | 土壤养分检测仪_肥料养分检测仪_土壤水分检测仪-山东莱恩德仪器 大型多片锯,圆木多片锯,方木多片锯,板材多片锯-祥富机械有限公司 | 电液推杆生产厂家|电动推杆|液压推杆-扬州唯升机械有限公司 | 冷水机,风冷冷水机,水冷冷水机,螺杆冷水机专业制造商-上海祝松机械有限公司 | 净化车间_洁净厂房_净化公司_净化厂房_无尘室工程_洁净工程装修|改造|施工-深圳净化公司 | SRRC认证|CCC认证|CTA申请_IMEI|MAC地址注册-英利检测 | 贴片电容-贴片电阻-二三极管-国巨|三星|风华贴片电容代理商-深圳伟哲电子 | 膏剂灌装旋盖机-眼药水灌装生产线-西林瓶粉剂分装机-南通博琅机械科技 | 天坛家具官网| 天一线缆邯郸有限公司_煤矿用电缆厂家_矿用光缆厂家_矿用控制电缆_矿用通信电缆-天一线缆邯郸有限公司 | 智慧养老_居家养老_社区养老_杰佳通| 分轨 | 上传文件,即刻分离人声和伴奏| 沈阳激光机-沈阳喷码机-沈阳光纤激光打标机-沈阳co2激光打标机 | 东风体检车厂家_公共卫生体检车_医院体检车_移动体检车-锦沅科贸 | 深圳装修_店面装修设计_餐厅设计_装修全包价格-尚泰装饰设计 | 衡阳耐适防护科技有限公司——威仕盾焊接防护用品官网/焊工手套/焊接防护服/皮革防护手套 | 洗瓶机厂家-酒瓶玻璃瓶冲瓶机-瓶子烘干机-封口旋盖压盖打塞机_青州惠联灌装机械 | Pos机办理_个人商户免费POS机申请-拉卡拉办理网| 软膜天花_软膜灯箱_首选乐创品牌_一站式天花软膜材料供应商! | MOOG伺服阀维修,ATOS比例流量阀维修,伺服阀维修-上海纽顿液压设备有限公司 | PU树脂_水性聚氨酯树脂_聚氨酯固化剂_聚氨酯树脂厂家_宝景化工 | ◆大型吹塑加工|吹塑加工|吹塑代加工|吹塑加工厂|吹塑设备|滚塑加工|滚塑代加工-莱力奇塑业有限公司 | 微水泥_硅藻泥_艺术涂料_艺术漆_艺术漆加盟-青岛泥之韵环保壁材 武汉EPS线条_EPS装饰线条_EPS构件_湖北博欧EPS线条厂家 | LED太阳能中国结|发光红灯笼|灯杆造型灯|节日灯|太阳能灯笼|LED路灯杆装饰造型灯-北京中海轩光电 | 纸张环压仪-纸张平滑度仪-杭州纸邦自动化技术有限公司 | 东莞精密模具加工,精密连接器模具零件,自動機零件,冶工具加工-益久精密 | 北京晚会活动策划|北京节目录制后期剪辑|北京演播厅出租租赁-北京龙视星光文化传媒有限公司 | 济南电缆桥架|山东桥架-济南航丰实业有限公司 | 美能达分光测色仪_爱色丽分光测色仪-苏州方特电子科技有限公司 | 成都热收缩包装机_袖口式膜包机_高速塑封机价格_全自动封切机器_大型套膜机厂家 | Boden齿轮油泵-ketai齿轮泵-yuken油研-无锡新立液压有限公司 | 婚博会2024时间表_婚博会门票领取_婚博会地址-婚博会官网 | 通用磨耗试验机-QUV耐候试验机|久宏实业百科 | 减速机三参数组合探头|TSM803|壁挂式氧化锆分析仪探头-安徽鹏宸电气有限公司 | 碳化硅,氮化硅,冰晶石,绢云母,氟化铝,白刚玉,棕刚玉,石墨,铝粉,铁粉,金属硅粉,金属铝粉,氧化铝粉,硅微粉,蓝晶石,红柱石,莫来石,粉煤灰,三聚磷酸钠,六偏磷酸钠,硫酸镁-皓泉新材料 | 氧化锆陶瓷_氧化锆陶瓷加工_氧化锆陶瓷生产厂家-康柏工业陶瓷有限公司 | 软瓷_柔性面砖_软瓷砖_柔性石材_MCM软瓷厂家_湖北博悦佳软瓷 | 济南律师,济南法律咨询,山东法律顾问-山东沃德律师事务所 | 钢化玻璃膜|手机钢化膜|钢化膜厂家|手机保护膜-【东莞市大象电子科技有限公司】 | 日本SMC气缸接头-速度控制阀-日本三菱伺服电机-苏州禾力自动化科技有限公司 | 谈股票-今日股票行情走势分析-牛股推荐排行榜|