一.通过Navicat工具,进入mysql数据库,在查询编辑器中输入:
select @@global.time_zone,@@session.time_zone;

System代表采用系统时区 CST 是一种比较乱的时区,它包括了4个时区 CST可视为美国、澳大利亚、古巴或中国的标准时间。 同时代表了下面4个时区: 1、CST Central Standard Time(USA)UT-6:00。 2、CST Central Standard Time(Australia)UT9:30。 3、CST China Standard Time UT8:00。 4、CST Cuba Standard Time UT-4:00。 由于世界各国家与地区经度不同,地方时也有所不同,因此会划分为不同的时区。正式的时区划分包括24个时区,每一时区由一个英文字母表示。每隔经度15°划分一个时区,有一个例外,每个时区有一条中央子午线;例如,GMT属于“z”区,因此其时间后通常添加后缀“Z”
show variables like ‘%time_zone%’;

二.在查询编辑器中直接输入以下命令
方法1:使用命令(优点:不需要重启MySQL服务,缺点:一旦MySQL服务被重启,设置就会消失)
set global time_zone = ‘+8:00’;
这个可以修改mysql全局时区为北京时间,也就是我们所在的东8区
set time_zone = ‘+8:00’;
修改当前会话时区
flush privileges;
使之立即生效。
方法2:修改my.ini配置文件(优点:永久保存设置,缺点:需重启MySQL服务)
修改配置文件 /etc/my.cnf
[mysqld] default-time_zone = '+8:00'
三.查询时间,检验时间对不对 (验证时区,这行命令可以检测session.time_zone是否正确配置)
select now();

没有用的话重启mysql试一下
systemctl stop mysqld.service systemctl start mysqld.service
备注:在项目中的,也要及时更改 java中的时区
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/226057.html原文链接:https://javaforall.net
