zoukankan      html  css  js  c++  java
  • DATE类型数据在MySql中减一天的问题

    最近在开发一个教务管理系统,数据库中有教师表(Teacher)、学生表(Student)等,其中属性:出生日期(Birthday)为DATE类型。

    在执行更新教师操作时,发现未改动教师的出生日期但更新后的日期却减少了一天,最初以为是自己传值地方写错了,但是经过追踪发现传值时日期一切正常,但是更新后日期却又减少一天。

    最后发现是因为最新的数据库驱动中时区设置的原因。这种情况在DATE类型数据插入、更新时均会发生。

    最新的MySql数据库连接驱动为

    jdbc.driver=com.mysql.cj.jdbc.Driver

    其中URL配置为

    jdbc.url=jdbc:mysql://localhost:3306/xxx?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=CONVERT_TO_NULL&useSSL=false&serverTimezone=UTC

    一般默认serverTimezone配置为UTC,但是这样的日期与系统日期有八个小时的时差

    那么如何解决这样的问题呢?

    只需要将serverTimezone设置为Asia/Shanghai或者HongKong,问题就解决了。

    jdbc.url=jdbc:mysql://localhost:3306/xxx?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=CONVERT_TO_NULL&useSSL=false&serverTimezone=Asia/Shanghai

    旧版本的MySql数据库驱动无需配置时区等

    jdbc.driver=com.mysql.jdbc.Driver
  • 相关阅读:
    http连接池
    消息队列场景简介
    项目中使用到的设计模式
    dubbo 问题整理
    dubbo Filter
    Elastic-Job分布式作业框架
    别被平凡淹没
    spring中@value注解需要注意
    穷人的真相:从7点忙到23点的上班者,跳出穷人圈子唯一可能是.
    ContextLoaderListener类(spring源码解析)
  • 原文地址:https://www.cnblogs.com/MK-XIAOYU/p/10611919.html
Copyright © 2011-2022 走看看