• 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
  • 相关阅读:
    状态管理cookie 案例
    JavaScript对象(document对象 图片轮播)
    JavaScript对象(窗口对象 定时器对象 )
    JavaScript对象(正则表达式,Date对象,function对象 arguments对象)
    CSS概述<选择器总结>
    HTML表单
    Web表格
    JDBC项目实践
    JDBC获取表的主键
    JDBC中DAO事务函数模版
  • 原文地址:https://www.cnblogs.com/MK-XIAOYU/p/10611919.html
Copyright © 2020-2023  润新知