最近在用mybatis時發現,將LocalDateTime插入到資料庫時時間少了8小時,
用網上其他方法試了不少,比如修改mysql時區,都不能解決,最后發現是JDBC連接的引數寫錯了,
經常在網上看到jdbc連接里邊有這樣一個引數&serverTimezone=UTC,這個UTC是協調世界時,我們中國在東八區,也就是UTC+8,和UTC差了8個小時,2021Java面試寶典
這就是為什么時間插入資料庫后少了8小時的原因,那么中國的時區是多少呢?在java.time.ZoneId這個類的幫助檔案和原始碼里寫有:
-
EST - -05:00
-
HST - -10:00
-
MST - -07:00
-
ACT - Australia/Darwin
-
AET - Australia/Sydney
-
AGT - America/Argentina/Buenos_Aires
-
ART - Africa/Cairo
-
AST - America/Anchorage
-
BET - America/Sao_Paulo
-
BST - Asia/Dhaka
-
CAT - Africa/Harare
-
CNT - America/St_Johns
-
CST - America/Chicago
-
CTT - Asia/Shanghai
-
EAT - Africa/Addis_Ababa
-
ECT - Europe/Paris
-
IET - America/Indiana/Indianapolis
-
IST - Asia/Kolkata
-
JST - Asia/Tokyo
-
MIT - Pacific/Apia
-
NET - Asia/Yerevan
-
NST - Pacific/Auckland
-
PLT - Asia/Karachi
-
PNT - America/Phoenix
-
PRT - America/Puerto_Rico
-
PST - America/Los_Angeles
-
SST - Pacific/Guadalcanal
-
VST - Asia/Ho_Chi_Minh
可以看到CTT - Asia/Shanghai,所以我們在jdbc的連接里使用&serverTimezone=CTT就可以正確的插入時間了,
比較簡單的一個問題,有多少胖友碰到過呀?
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/261610.html
標籤:Java
