解决MySQL存储时间出现不一致的问题
程序员文章站
2022-03-16 10:07:14
用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创建数据库后出现:Access denied for user 'root'@'%' to database 'xxx'的问题
-
linux安装mysql5.7.22配置文件my.cnf配置细节及修改密码时出现的问题解决
-
mysql出现无法使用、无法启动服务问题的解决方法
-
解决MYSQL出现Can''t create/write to file ''#sql_5c0_0.MYD''的问题
-
解决MySQL8.0安装第一次登陆修改密码时出现的问题
-
解析MySQL中存储时间日期类型的选择问题
-
解决MYSQL出现Can''t create/write to file ''#sql_5c0_0.MYD''的问题
-
mysql/mariadb学习过程中出现的问题与解决
-
解决Windows和Linux双系统时间不一致的问题
-
在PHP+Apache+MySQL环境下(windows系统),连接SQLServer数据出现“can not find driver”问题的解决办法