当前位置: 代码迷 >> 综合 >> [转](1条消息)JDBC连接数据库 mysql serverTimezone useSSL 时差
  详细解决方案

[转](1条消息)JDBC连接数据库 mysql serverTimezone useSSL 时差

热度:39   发布时间:2024-02-02 05:37:30.0

 

驱动包用的是mysql-connector-java-8.0.11.jar
新版的驱动类改成了com.mysql.cj.jdbc.Driver
新版驱动连接url也有所改动
I、指定时区

//北京时间东八区
serverTimezone=GMT%2B8 

这个时区要设置好,不然会出现时差,
如果你设置serverTimezone=UTC,连接不报错,
但是我们在用java代码插入到数据库时间的时候却出现了问题。
比如在java代码里面插入的时间为:2018-06-24 17:29:56
但是在数据库里面显示的时间却为:2018-06-24 09:29:56
有了8个小时的时差
UTC代表的是全球标准时间 ,但是我们使用的时间是北京时区也就是东八区,领先UTC八个小时。

//北京时间东八区
serverTimezone=GMT%2B8 
//或者使用上海时间
serverTimezone=Asia/Shanghai

为何没有asia/beijing时区?
II、指定是否用ssl连接,true值还报错了

useSSL=false

完整代码:

Class.forName("com.mysql.cj.jdbc.Driver");String url="jdbc:mysql://localhost:3306/mydb3?serverTimezone=GMT%2B8&useSSL=false";String user="root";String password="123";Connection connection = DriverManager.getConnection(url, user, password);System.out.println(connection);

1、导包mysql-connector-java-8.0.11.jar
2、加载驱动类

Class.forName("com.mysql.cj.jdbc.Driver");

3、定义url,user,password

String url="jdbc:mysql://localhost:3306/mydb3?serverTimezone=GMT%2B8&useSSL=false";String user="root";String password="123";

4、通过DriverManager.getConnection得到connection

Connection connection = DriverManager.getConnection(url, user, password);


---------------------
作者:love20yh
来源:CSDN
原文:https://blog.csdn.net/love20yh/article/details/80799610
版权声明:本文为作者原创文章,转载请附上博文链接!

  相关解决方案