首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Mysql正在保存从java应用程序输入的日期早1天的日期。

Mysql正在保存从java应用程序输入的日期早1天的日期。
EN

Stack Overflow用户
提问于 2018-09-24 05:37:53
回答 2查看 3.8K关注 0票数 5

我在当前的项目(生产)中使用以下规格

  1. 操作系统: CentOS 7
  2. 数据库: MySql
  3. Java 8
  4. Hibernate
  5. tomcat服务器8

与应用服务器相比,数据库位于单独的服务器中,但两者都位于同一个LAN中。

mysql表中的数据类型是:只存储日期的date和保存时间的datetime

问题是mysql将每一个日期都提前了一天,而不是从鼓掌中提供的日期。到目前为止,我已经尝试过以下几种方法,但仍然没有成功:

  1. 我已经将应用程序和数据库服务器的时区设置为Asia/Dhaka,并从我的java应用程序中检查了这一点。
  2. 我还在tomcat服务器(setenv.sh)文件中设置了时区。
  3. 我还在log4j属性文件中检查了hibernate通过跟踪生成的sql,其中的日期也与输入日期相同。

我遗漏了什么?有人能提出建议吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-09-24 10:09:44

感谢大家分享你们在这个问题上的经验。

最后,通过改变java应用程序的serverTimezone连接字符串的dispatcher-servlet属性来解决该问题。

代码语言:javascript
运行
复制
<property name="url" value="jdbc:mysql://x.x.x..x:3306/dbname?characterEncoding=utf-8&amp;useSSL=false&amp;serverTimezone=Asia/Dhaka" /> 
票数 2
EN

Stack Overflow用户

发布于 2019-04-23 09:14:23

也许您可以尝试更改serverTimezone

代码语言:javascript
运行
复制
serverTimezone=GMT%2B8
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52473215

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档