java连接mysql时区修改_如何使用Java更改数据库连接中的MySQL时区?

useTimezone是一种较旧的解决方法. MySQL团队最近重写了setTimestamp / getTimestamp代码,但只有在设置连接参数useLegacyDatetimeCode = false并且使用最新版本的mysql JDBC连接器时才会启用它.例如:

String url =

"jdbc:mysql://localhost/mydb?useLegacyDatetimeCode=false

如果你下载mysql-connector源代码并查看setTimestamp,很容易看出发生了什么:

如果使用旧日期时间代码= false,则调用newSetTimestampInternal(…).然后,如果传递给newSetTimestampInternal的Calendar为NULL,则日期对象的格式为数据库的时区:

this.tsdf = new SimpleDateFormat("''yyyy-MM-dd HH:mm:ss", Locale.US);

this.tsdf.setTimeZone(this.connection.getServerTimezoneTZ());

timestampString = this.tsdf.format(x);

Calendar是空的非常重要 – 所以请确保您正在使用:

setTimestamp(int,Timestamp).

…不是setTimestamp(int,Timestamp,Calendar).

现在应该很明显这是如何工作的.如果您使用java.util.Calendar构建日期:2011年1月5日凌晨3:00在America / Los_Angeles(或您想要的任何时区)并调用setTimestamp(1,myDate),那么它将占用您的日期,使用SimpleDateFormat在数据库时区中格式化它.因此,如果您的数据库位于America / New_York,它将构造要插入的字符串’2011-01-05 6:00:00′(因为纽约比洛杉矶提前3小时).

要检索日期,请使用getTimestamp(int)(不使用Calendar).它将再次使用数据库时区来构建日期.

注意:网络服务器时区现在完全不相关!如果未将useLegacyDatetimecode设置为false,则使用Web服务器时区进行格式化 – 增加了许多混淆.

注意:

MySQL我可能会抱怨服务器时区不明确.例如,如果您的数据库设置为使用EST,则Java中可能存在多个可能的EST时区,因此您可以通过告知它确切的数据库时区来澄清这个问题:

String url =

"jdbc:mysql://localhost/mydb?useLegacyDatetimeCode=false&serverTimezone=America/New_York";

如果它抱怨,你只需要这样做.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是使用Java连接MySQL数据库的基本步骤: 1. 导入MySQL JDBC驱动包。可以从MySQL官网下载JDBC驱动包,然后将其复制到项目的classpath。 2. 加载JDBC驱动程序。使用以下代码加载MySQL JDBC驱动程序: ``` Class.forName("com.mysql.jdbc.Driver"); ``` 3. 创建连接使用以下代码创建与MySQL数据库连接: ``` String url = "jdbc:mysql://localhost:3306/test?useSSL=false&serverTimezone=UTC"; String username = "root"; String password = "password"; Connection conn = DriverManager.getConnection(url, username, password); ``` 其,url为连接字符串,test为要连接数据库名,localhost为MySQL服务器的地址,3306为MySQL服务器的端口号,useSSL=false表示不使用SSL连接,serverTimezone=UTC表示使用UTC时区,username为MySQL登录用户名,password为MySQL登录密码。 4. 执行SQL语句。可以使用Statement或PreparedStatement对象执行SQL语句。例如: ``` Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM users"); while (rs.next()) { int id = rs.getInt("id"); String name = rs.getString("name"); String email = rs.getString("email"); // ... } rs.close(); stmt.close(); ``` 5. 关闭连接使用以下代码关闭与MySQL数据库连接: ``` conn.close(); ``` 以上就是使用Java连接MySQL数据库的基本步骤。需要注意的是,连接字符串的格式和用户名、密码等信息应该根据实际情况进行修改

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值