主页 > 知识库 > 解决MySQL存储时间出现不一致的问题

解决MySQL存储时间出现不一致的问题

热门标签:html地图标注并导航 400电话办理服务价格最实惠 400电话变更申请 武汉电销机器人电话 北京金伦外呼系统 催天下外呼系统 大丰地图标注app 吕梁外呼系统 南太平洋地图标注

用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/ShanghaiuseSSL=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中存储时间日期类型的选择问题
  • MySQL存储时间类型选择的问题讲解
  • 如何选择合适的MySQL日期时间类型来存储你的时间
  • mysql获取指定时间段中所有日期或月份的语句(不设存储过程,不加表)
  • MySQL中存储时间的最佳实践指南

标签:自贡 徐州 丽水 西宁 无锡 迪庆 南充 龙岩

巨人网络通讯声明:本文标题《解决MySQL存储时间出现不一致的问题》,本文关键词  解决,MySQL,存储,时间,出现,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《解决MySQL存储时间出现不一致的问题》相关的同类信息!
  • 本页收集关于解决MySQL存储时间出现不一致的问题的相关信息资讯供网民参考!
  • 推荐文章