• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    解决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/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慢查询的坑
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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