mysql版本:myql-connector-java-8.0.11.jar
mybatis3連接數據庫代碼如下:
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;
}
}
執行結果:
OPT_DATATIME爲數據庫實際結果(OPT_DATATIME是轉爲字符串取出的數據)。OPT_DATETIME0爲Java自動轉類型(java.sql.TimeStamp)後的數據。上述兩個時間相差13/14小時,由於不是相差固定一個值所以排除時區的問題,在找問題的路上繼續前行。
【解決】: 在使用mysql的6.0.x以上的jar的時候,需要在代碼url的鏈接裏面指定serverTimezone。 UTC代表的是全球標準時間 ,但是我們使用的時間是北京時區也就是東八區,領先UTC八個小時。 URL的時區使用中國標準時間。按如下配置即可
jdbc:mysql://localhost:3306/springdatastudy?serverTimezone=Asia/Shanghai