小编给大家分享一下如何解决MySQL存储时间出现不一致的问题,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!用Java在获取了系统时间后,存入Mysql数据库时,当时间的类型为datetime或Timestamp时发现数据库
小编给大家分享一下如何解决MySQL存储时间出现不一致的问题,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
用Java在获取了系统时间后,存入Mysql数据库时,当时间的类型为datetime或Timestamp时发现数据库的存储与本地时间不一致。
很大原因是,mysql设置的时区与你本地时区不一致造成的,解决办法可以修改Mysql的时区配置,这个大家网上搜一下就有了。
就是在数据库连接的那个DBUtil类里根据你项目的实际需要进行设置,不如我在如下代码里更改了时区与亚洲上海同时区
private static String driver = "com.mysql.cj.jdbc.Driver"; private static String url = "jdbc:mysql://127.0.0.1:3306/mypetstore?serverTimezone=Asia/Shanghai&useSSL=false";
serverTimezone=Asia/Shanghai就是用来设置时区的。
在从MySQL里取出Timestamp数据时,显示到浏览器的时候,总会在末尾出现一个.0,很讨厌,怎么办呢?
可以使用如下EL表达式和jsTL标签的将其格式化,其中log.date就是所查出的时间数据
<fmt:fORMatDate value="${log.date}" type="date" pattern="yyyy-MM-dd HH:mm:ss" />
注意:若写成yyyy-MM-dd hh:mm:ss这样将区分不了上午与下午
补充:Mysql存储时间或日期错位问题
这里说一下mysql数据库添加记录的时候,出现日期错位一天或者时间不对的问题。
代码逻辑没问题,单步执行发现存的时候日期也没错,但是存到数据库日期就不对了。
原因就是你配置数据源连接加的参数内容的问题,如果没猜错你配置的serverTimezone这个参数应该是UTC,这个是使用的时区不对导致存数据的时候日期错位。
把serverTimezone设置成Asia/Shanghai,如下图,这样再试一下,问题就解决了。
看完了这篇文章,相信你对“如何解决MySQL存储时间出现不一致的问题”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网数据库频道,感谢各位的阅读!
--结束END--
本文标题: 如何解决MySQL存储时间出现不一致的问题
本文链接: https://www.lsjlt.com/news/275201.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-05-15
2024-05-15
2024-05-15
2024-05-15
2024-05-15
2024-05-15
2024-05-15
2024-05-15
2024-05-15
2024-05-15
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0