【Mysql】利用Mybatis3鏈接mysql獲取datetime類型數據錯誤

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
相關文章
相關標籤/搜索