标签:java mysql timezone database-connection
MySQL以时区“GMT 8”运行,但Tomcat使用“GMT”运行.当我将datetime保存到我的数据库时,一切似乎都没问题,但是当我检查数据库中的datetime值时,我看到了“GMT”值.
此外,当我尝试从数据库中获取值的值时,似乎数据库中的值被视为“GMT 8”,因此Java将值更改为“GMT”.
我已经设置了这样的连接URL:
useTimezone=true&serverTimezone=GMT
但它不起作用.
解决方法:
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";
如果它抱怨,你只需要这样做.
标签:java,mysql,timezone,database-connection 来源: https://codeday.me/bug/20190916/1808596.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。