主页 > 知识库 > 解决MySQL8.0时区的问题步骤

解决MySQL8.0时区的问题步骤

热门标签:北京人工外呼系统价钱 云南语音外呼系统平台 房产智能外呼系统品牌 沃克斯电梯外呼线路图 400电话郑州申请 福州呼叫中心外呼系统哪家好 常州电销外呼系统一般多少钱 地图标注被骗三百怎么办 天智外呼系统

软件版本

  • Windows:Windows10
  • MySQL:mysql-8.0.16-winx64.zip

问题描述

java将当前时间保存到MySQL数据库时,MySQL中的时间不正确

问题分析

原因一:java数据库连接使用UTC时区(世界标准时间),即serverTimezone=UTC

url: jdbc:mysql://localhost:3306/test?serverTimezone=UTCuseUnicode=truecharacterEncoding=utf8useSSL=true

原因二:MySQL使用的time_zone属性是+00:00,而北京时间比UTC时间早8小时,即UTC+08:00

检查MySQL

/**
 * 可查看全局的时区设置和会话的时区设置
 * global.time_zone负责java连接数据库时的时区设置
 * session.time_zone负责Navicat客户端连接数据库时的时区设置
 * /
mysql> select @@global.time_zone,@@session.time_zone;

/**
 * 还有一种方法
 * System代表采用系统时区
 * CST是一种很乱的时区,它包括了4个时区
 * /
mysql> show variables like '%time_zone%'; 

// 验证时区,这行命令可以检测session.time_zone是否正确配置
mysql> select now();

解决方法

步骤一:修改java中的时区为东八区

// serverTimezone可以设置为北京时间GMT%2B8、上海时间Asia/Shanghai或者香港时间Hongkong
url: jdbc:mysql://localhost:3306/test?serverTimezone=Asia/ShanghaiuseUnicode=truecharacterEncoding=utf8useSSL=true

步骤二:修改MySQL数据库的时区为东八区

// 方法一:使用命令(优点:不需要重启MySQL服务,缺点:一旦MySQL服务被重启,设置就会消失)
mysql> set time_zone = '+8:00';
mysql> set global time_zone = '+8:00';
// 方法二:修改my.ini配置文件(优点:永久保存设置,缺点:需重启MySQL服务)
[mysqld]
// 设置默认时区
default-time_zone='+8:00'

到此这篇关于解决MySQL8.0时区的问题步骤的文章就介绍到这了,更多相关MySQL8.0时区内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • mysql解决时区相关问题
  • 关于Java中的mysql时区问题详解
  • MySQL查看和修改时区的方法
  • MySQL修改时区的方法小结
  • 详解MySQL查询时区分字符串中字母大小写的方法
  • mysql时区问题

标签:珠海 拉萨 移动 黔东 沈阳 沈阳 徐州 盐城

巨人网络通讯声明:本文标题《解决MySQL8.0时区的问题步骤》,本文关键词  解决,MySQL8.0,时区,的,问题,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《解决MySQL8.0时区的问题步骤》相关的同类信息!
  • 本页收集关于解决MySQL8.0时区的问题步骤的相关信息资讯供网民参考!
  • 推荐文章