mysql版本:myql-connector-java-8.0.11.jarhtml
mybatis3鏈接數據庫代碼以下:java
public interface HeXinMapper { @SelectProvider(type = HeXinProvider.class, method = "test") List<Map<String, Object>> test(@Param("acct_nbr") String acct_nbr); } public class HeXinProvider { public String test(){ String sql = "SELECT T.OPT_DATETIME AS OPT_DATETIME0, DATE_FORMAT(T.OPT_DATETIME,'%Y-%m-%d %H:%i:%s') AS OPT_DATETIME FROM CCS_ORDER_HST T WHERE T.ACCT_NBR in ('2086437','3444927','3445082','3445090','3445138','3445745','3590115','3700069','3751062','3751321','3802981')"; return sql; } }
執行結果:mysql
OPT_DATATIME爲數據庫實際結果(OPT_DATATIME是轉爲字符串取出的數據)。OPT_DATETIME0爲Java自動轉類型(java.sql.TimeStamp)後的數據。上述兩個時間相差13/14小時,因爲不是相差固定一個值因此排除時區的問題,在找問題的路上繼續前行。spring
【解決】: 在使用mysql的6.0.x以上的jar的時候,須要在代碼url的連接裏面指定serverTimezone。 UTC表明的是全球標準時間 ,可是咱們使用的時間是北京時區也就是東八區,領先UTC八個小時。 URL的時區使用中國標準時間。按以下配置便可sql
jdbc:mysql://localhost:3306/springdatastudy?serverTimezone=Asia/Shanghai