MySQL时区问题及JDBC连接MySQL的时区问题

什么是时区

由于世界各国家与地区经度不同,地方时也有所不同,因此会划分为不同的时区。正式的时区划分包括24个时区,每一时区由一个英文字母表示。每隔经度15°划分一个时区,有一个例外,每个时区有一条中央子午线;例如,GMT属于“z”区,因此其时间后通常添加后缀“Z”(口语中用后缀“Zulu”)。 [1]

问题

  • 往数据库中存入的时间少了14小时
    • 原因 (MySQL版本8.0)
      1 .在设置数据源的时候没有指定数据库时区,url: jdbc:mysql://localhost:3306/test ?serverTimezone=Asia/Shanghai , 在windows中如果没有指定这个参数,访问数据库的时候就会报错,但是在mac中可以,是因为windows中system_time_zone的值是空的,而mac中的默认的system_time_zone是CST。
      2.数据库在启动的时候会使用系统的时区,中国的时区是CST(China Standard Time utc+8),在解析成预编译语句的时候,误将CST解析成CST(Central Standard Tim UTC-6),美国中部标准时间,所以少14个小时”。 CST是一个很混乱的时区,有四个时区的缩写都是这个(。。。。)
  • 使用@JsonFormat解析时间
    • 使用@JsonFormat(patten=“yyyy-MM-dd HH:mm:ss” timezon=“GMT+8”)解析时间,这样才能向前端返回正确的时间json,因为JsonFormat在解析时间的时候,默认是带着UTC时区去解析的,这样就会导致解析出来的时间与东八区相差8个小时。
  • 使用@DateTimeFormat接收前端的时间参数
    • 使用@DateTimeFormat(pattern = “yyyy-MM-dd HH:mm:ss”)接受前端的时间,格式只能与patten相同,否则无法解析,将会报错。

关于MySQL的时区

时区变量
  • 全局时区变量 time_zone,这个值可以在MySQL服务启动时指定,如果没有指定,则默认值时SYSTEM,表示与系统相同。
    SET GLOBAL time_zone = timezone;(指定全局时区变量,须持有SUPER权限)
  • 会话时区变量 time_zone,每个连接的 Client 端都有自己的会话时区设置,由会话time_zone变量指定。最初,会话变量从全局time_zone变量获取其值,但是 Client 端可以使用以下语句更改其自己的时区:
    SET time_zone = timezone;
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值