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