mysql遇到時區問題的坑(Java解決方案)


最近項目遇到一個坑,就是server和db之間存在時區問題,本人的db是utc時間,

可以使用代碼設置時區來解決,本人這里使用joda三方包,joda蠻好用的,具體用法這里不做詳細描述。

先引入pom

<dependency>
  <groupId>joda-time</groupId>
  <artifactId>joda-time</artifactId>
  <version>2.10.1</version>
</dependency>

下面在使用的地方加上下面一句即可。

// 這里使用UTC,還有其他的配置參數,比如: Asia/Shanghai   Asia/Chongqin  等等
DateTime utcDT = new DateTime().withZone(DateTimeZone.UTC).toLocalDateTime().toDateTime(); ... ... ... UserDto dto = new UserDto(); dto.setCreated(utcDT.toDate()); userMapping.insertRecords(dto);

 

除了上面的方法外,還可以在驅動器的連接URL上加參數,如下:

spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/xxx?useUnicode=true&characterEncoding=utf8
&allowMultiQueries=true&useLegacyDatetimeCode=false&serverTimezone=UTC
spring.datasource.username=root spring.datasource.password=111111
說明:useLegacyDatetimeCode=false 關鍵是這個參數,
引用:http://www.voidcn.com/article/p-eqvuhiio-bsb.html 這里有詳細的介紹

附上mysql官網文檔:https://dev.mysql.com/doc/connector-j/5.1/en/connector-j-reference-configuration-properties.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM