色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

關于SpringBoot mysql數據庫時區問題

瀏覽:35日期:2023-03-06 08:36:12
尋找原因

后端開發中常見的幾個時區設置

第一個設置點配置文件 spring.jackson.time-zone

第二個設置點 高版本SpringBoot版本 mysql-connector-java 用的是8.X,mysql8.X的jdbc升級了,增加了時區(serverTimezone)屬性,并且不允許為空。

第三個設置點 mysql time_zone變量

詞義

serverTimezone臨時指定mysql服務器的時區

spring.jackson.time-zone 設置spring默認時區

system_time_zone mysql服務器時區 ,time_zone默認System追隨system_time_zone

幾種情況

1、time_zone 為 System,serverTimezone為GMT+8,jackson.time-zone未定義

關于SpringBoot mysql數據庫時區問題

插入情況

關于SpringBoot mysql數據庫時區問題

關于SpringBoot mysql數據庫時區問題

關于SpringBoot mysql數據庫時區問題

再查詢此條記錄

關于SpringBoot mysql數據庫時區問題

個人覺得Spring默認時區為格林尼治時區,web服務器當前時區為東八區,進行加8操作。

2、set GLOBAL time_zone = ’+3:00’,serverTimezone為GMT+8,jackson.time-zone為GMT+8

createTime 為 timestamp類型

關于SpringBoot mysql數據庫時區問題

修改配置后,需要重啟SpringBoot

新增情況

關于SpringBoot mysql數據庫時區問題

數據庫中顯示

關于SpringBoot mysql數據庫時區問題

查詢記錄

關于SpringBoot mysql數據庫時區問題

個人理解,serverTimezone設置覆蓋掉了mysql的time_zone變量,跟SpringBoot回話時區還是東8

3、上述環境,不重啟SpringBoot,直接改變time_zone = ’+5:00’

改變后,上條記錄往后調整2小時。

關于SpringBoot mysql數據庫時區問題

SpringBoot查詢,一樣

關于SpringBoot mysql數據庫時區問題

說明,timeStamp類型存儲的是格林尼治時間,加上time_zone時區

當time_zone變化時,回話沒結束,serverTimeZone東8還是對應time_zone的東3

SpringBoot插入

關于SpringBoot mysql數據庫時區問題

關于SpringBoot mysql數據庫時區問題

個人理解,serverTimeZone東8 還是和 time_zone 東3對應,但是插入發現 當前time_zone已經改成東5,就加2小時。

重啟SpringBoot,重新查詢

關于SpringBoot mysql數據庫時區問題

關于SpringBoot mysql數據庫時區問題

雖然,mysql變量time_zone為+5,但是重啟后,serverTimeZone直接覆蓋,設置時間區間為東8

重新把time_zone改回東3

關于SpringBoot mysql數據庫時區問題

改回重新打開表,發現又回來了

不啟動SpringBoot,查詢數據,還是老樣子

關于SpringBoot mysql數據庫時區問題

此時,添加一條數據。

關于SpringBoot mysql數據庫時區問題

往前推了2小時。

關于SpringBoot mysql數據庫時區問題

SpringBoot查詢

關于SpringBoot mysql數據庫時區問題

重啟SpringBoot,查出來就是庫中數據。

關于SpringBoot mysql數據庫時區問題

總結:

1、timeStamp類型存儲時間數據,當time_zone和serverTimeZone不統一情況,會話中,表中時間數據,按照serverTimeZone設定

2、如果過程中,修改了time_zone變量,庫中數據直接變更。但是不影響當前會話查詢,新增數據,就會根據time_zone調整量,調整實際入庫。

3、SpringBoot重啟,其實就是新會話。情況同上。

4、時間字段類型為datetime,serverTimezone為GMT+8,jackson.time-zone為GMT+8,time_zone為東3

插入

關于SpringBoot mysql數據庫時區問題

庫中

關于SpringBoot mysql數據庫時區問題

查詢

關于SpringBoot mysql數據庫時區問題

time_zone從東3修改為東5

重新打開庫

關于SpringBoot mysql數據庫時區問題

不啟動SpringBoot

關于SpringBoot mysql數據庫時區問題

重啟SpringBoot,還是一樣。

修改serverTimeZone為GMT,其他不改動

關于SpringBoot mysql數據庫時區問題

關于SpringBoot mysql數據庫時區問題

查詢

關于SpringBoot mysql數據庫時區問題

總結:如果是datetime類型,serverTimeZone說了算。

以上就是關于SpringBoot mysql數據庫時區問題的詳細內容,更多關于SpringBoot mysql時區的資料請關注好吧啦網其它相關文章!

標簽: Spring
相關文章:
主站蜘蛛池模板: 欧美成人中文字幕 | 综合亚洲一区二区三区 | 国产盗摄一区二区 | 久99久精品视频免费观看v | 亚洲另类自拍 | 精品综合久久久久久98 | 中文字幕日韩在线 | 欧美黑人性xxx猛交 欧美很黄视频在线观看 | 99久久99久久久99精品齐 | 亚洲成人免费观看 | 成年人黄色免费网站 | 久久99这里只有精品国产 | 长腿校花被啪到腿软视频 | 特黄日韩免费一区二区三区 | a级片在线免费观看 | 国产特黄一级毛片特黄 | 欧美人成片免费看视频不卡 | 国产手机看片 | 极品色在线精品视频 | 国产激情一区二区三区成人91 | 久久精品国产大片免费观看 | 成人高清视频在线观看 | 青青草国产免费一区二区 | 91国语精品自产拍在线观看一 | 成人怡红院视频在线观看 | 亚洲欧美精品中字久久99 | 亚洲日韩aⅴ在线视频 | 欧美视频在线网站 | 在线观看免费黄色网址 | 波多野结衣中文视频 | 亚洲精品国自产拍在线观看 | 日韩亚洲欧美一区二区三区 | 亚洲美女福利视频在线 | 在线观看日本免费视频大片一区 | 久久精品国产半推半就 | 亚洲第一色网 | 欧美在线一级va免费观看 | 2022国产精品自拍 | 中文字幕在线视频网站 | 国产精品久久久久影视不卡 | 国产a网站 |