数据库连接mysql时区设置_如何使用Java在数据库连接中更改MySQL时区?

本文介绍了如何在Java数据库连接中正确设置MySQL时区,强调了使用`useLegacyDatetimeCode=false`的重要性,并提供了设置URL示例,以避免时区混淆问题。通过设置服务器时区参数如`serverTimezone=America/New_York`,可以确保时间戳的准确转换。
摘要由CSDN通过智能技术生成

小编典典

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);

日历为空非常重要-因此请确保您使用的是:

setTimestamp(int,Timestamp).

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

现在应该很清楚这是如何工作的。如果您使用java.util.Calendar在美国/洛杉矶(或您想要的任何

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值