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
  • 相关阅读:
    Python基础06 循环
    Python基础04 运算
    Python基础02 基本数据类型
    Python基础03 序列
    C++ ------ 引用
    C++ ------ 互斥锁、原子操作的性能测试
    Qt ------ 断开某对信号与槽的connect
    5种网络通信设计模型(也称IO模型)
    Qt ------ 主事件循环与 QEventLoop
    Qt ------ 再论事件循环
  • 原文地址:https://www.cnblogs.com/MK-XIAOYU/p/10611919.html
Copyright © 2011-2022 走看看