当前位置: 首页 > news >正文

MySQL 解决时区相关问题

在使用 MySQL 的过程中,你可能会遇到时区相关问题,比如说时间显示错误、时区不是东八
区、程序取得的时间和数据库存储的时间不一致等等问题。其实,这些问题都与数据库时区设
置有关。
MySQL Server 中有 2 个环境变量和时区有关,你通过下述 SQL 语句能查看得到它俩的值:

mysql> show global variables like '%time_zone%';

不出意外的话,你看到的大概是类似如下内容:

+------------------+--------+
| Variable_name | Value |
+------------------+--------+
| system_time_zone | CST |
| time_zone | SYSTEM |
+------------------+--------+

还有一种小概率的可能,你的 system_time_zone 的值是空的。

system_time_zone 环境变量


它的值是 MySQL server 启动时,它自己去查询到的其所在服务器的系统时区。这个值是我们
无法影响、改变的,除非你去动你的操作系统时区设置。
如果你的 Linux 操作系统开启了 NTP 服务的话,这个时区应该是你的电脑硬件所位于的真实
的、物理时区。
通常情况下,我们看到的这个环境变量的值是  CST :中国标准时间 ( 即,UTC+08:00 ) 。 这个值也有可能为空,那就是你系统时区设置有问题。
但是 CST 有个问题:还有另外的三个时区 ( 美国中部时间、澳大利亚中部时间、古巴标准时 ) 缩写也叫 CST ,这就导致了你如果使用 CST 来代表你的时区的话,那么它有可能会引起歧义。简
单来说,你从『中国标准时间』这个说法可以“得到” CST ,但是你从 CST 不一定能反推出
『中国标准时间』这个说法。
system_time_zone 环境变量的值和我们未来使用 MySQL 并没有直接的关系,但是有间接关
系:它的值是 time_zone 环境变量的默认值 。
对于你的 Linux 操作系统的时区,你可以通过如下命令查看得到:

# 时区显示的是 CST
date
# 时区显示的是 +0800
date -R

time_zone 环境变量


MySQL Server 通过这个环境变量实现了这样的一个功能:你可以无视 MySQL Server 实际所
在的时区,而强行认为、假想 MySQL Server 是在某个时区。此时,你的有关日期时间的操
作,都是基于这个你指定、假象的逻辑上的时区得到的数据。
在连上 MySQL Server 之后,执行如下命令,『强行认为』MySQL Server 位于东九区 ( 日本
所在时区 ) :

mysql> set time_zone = '+9:00';

这个操作意味着:在此次连接/会话过程中,你认为 MySQL Server 是位于东九区的服务器上
的 ( 而无视它真实所在地 ) 。

提示:

当然,你也不必对 time_zone 畏之如虎,它并非对所有的日期时间操作都有影响。就我
们的日常操作而言,受它影响的主要是  now() /  curtime() 函数和 TIMESTAMP 类型字
段。

now() 函数


在设置当前连接/会话的 time_zone ,即,指定你心里认为的 MySQL Server 所处于的时区之
后,执行如下命令向 MySQL Server “询问”当前时间:

mysql> select now(), curtime();

你会发现 MySQL Server “回复” 你的日期时间好像要比当下要快一个小时,这正是此时此刻
东九区 ( 日本 ) 的时间。

补充:

有三个 utc_X() 函数,它们永远返回的是当下的 UTC 时间,即格林威治时间 ( +0:00
) :

mysql> select utc_date(), utc_time(), utc_timestamp();

timestamp 类型


timestamp 类型的数据也会受到 time_zone 的影响。
当你通过 insert sql 语句,要求 MySQL Server 在 timestamp 类型的字段中存储  12:00
时,MySQL Server 考虑到自己现在是在一台东九区的服务器上,所以它存储的时间本质上就
是 UTC 标准时  3:00 。
未来,你再通过 select sql 语句,从 MySQL Server 中查询这个 timestamp 类型的值时,
MySQL Server 如果发现自己是在一台东八区的服务器上,那么它返回给你的就是东八区
11:00 。
你会发现:你存进去的是  12:00 ,但是取出来的是  11:00 。
timestamp 类型的数据也会受到 time_zone 的影响,这也是不建议使用 timestamp 的原因之
一。

提示:

date、time 和 datetime 类型不似 timestamp,它们不受 time_zeon 所设置的时区影
响。它们的值是多少就是多少,不会出现 timestamp 这种存进去是这个值,取出来是那
个值的情况。

默认值 SYSTEM


大家也看到了,time_zone 环境变量的默认值是 SYSTEM ,它的含义是『 time_zone 的值与
system_time_zone 环境变量的值保持一致』。在之前的例子中,这个值就是 CST ,即,东八
区。
为了减少 MySQL Server 对于服务器环境的依赖,以及前面提到的 CST 会引起歧义的问题,
通常我们最好还是自己指定 time_zone 的值,将它固定成事实上的、MySQL Server 其所在的
时区。
之前也见过,使用如下设置可以临时改变 time_zone 的值

-- 对当前连接生效
mysql> set time_zone = '+8:00';
-- 对此后的所有新连接/会话生效,但是 MySQL Server 重启后失效。
mysql> set global time_zone = '+8:00';

想要一劳永逸地修改它,你需要改动 mysql 配置文件,在配置文件  [mysqld]  部分增加一行:

default_time_zone = '+8:00'

另外,当 time_zone=system 的时候,调用 now(),或查询 timestamp 字段会调用系统的时
区做时区转换,有全局锁 __libc_lock_lock 的保护,可能导致线程并发环境下系统性能受
限。而改为'+8:00'则不会触发系统时区转换,使用 MySQL 自身转换,大大提高了性能。这也
是为什么建议改以下 time_zone ,不要让它是 SYSTEM 的原因之一。

JDBC 中的 serverTimezone


JDBC 在 MySQL 8.0 本之后要求连接的 URL 中要求必须带上 serverTimezone 属性,而之前
这个属性是非必须的。
在之前的版本中,当我们的 URL 中没有带上 serverTimezone 时,我们的程序与 MySQL
Server 之间的连接/会话的  time_zone 就是 MySQL Server 中的配置 ( 的默认值 ) 所决定的。
现在我们的 URL 中带上 serverTimezone 之后,就由我们 URL 中的这个值决定了。
不过,理论上,这个值也就应该等于我们的程序要连上的 MySQL Server 那台服务器所在的真
实、物理时区。
相差 13 小时或 14 小时
如果说相差 8 小时不够让人惊讶,那相差 13 小时可能会让很多人摸不着头脑。出现这个问
题的原因是 JDBC 与 MySQL 对「CST」时区协商不一致。因为 CST 时区是一个很混乱的时
区,有四种含义:
美国中部时间 Central Standard Time (USA) UTC-05:00 或 UTC-06:00
澳大利亚中部时间 Central Standard Time (Australia) UTC+09:30
中国标准时 China Standard Time UTC+08:00
古巴标准时 Cuba Standard Time UTC-04:00
MySQL 中,如果 time_zone 为默认的 SYSTEM 值,则时区会继承为系统时区 CST ,MySQL 内
部将其认为是 UTC+08:00 。而 jdbc 会将 CST 认为是美国中部时间,这就导致会相差 13 小
时,如果处在冬令时还会相差 14 个小时。
解决此问题的方法也很简单,我们可以明确指定 MySQL 数据库的时区,不使用引发误解的
CST ,可以将 time_zone 改为'+8:00',同时 jdbc 连接串中也可以增加
serverTimezone=Asia/Shanghai。


总结


为了保证不出现存取的日期时间有偏差的情况,大家务必确保如下几点:
1. MySQL Server 所在的服务器的系统时区尽量是正确的、真实的、物理时区;
default_time_zone = '+8:00'
2. 无论服务器的系统时区是否是对的,MySQL Server 的  time_zone 的值要通过修改配置文件
的方式,一劳永逸地确定下来,保证是正确的、真实的、物理时区;
3. JDBC 的 URL 中现在规定必须要带上 serverTimezone 参数,这个参数的值必须是 MySQL
Server 的所在的真实时区,即与  2 中的 time_zone 一致。

相关文章:

MySQL 解决时区相关问题

在使用 MySQL 的过程中,你可能会遇到时区相关问题,比如说时间显示错误、时区不是东八 区、程序取得的时间和数据库存储的时间不一致等等问题。其实,这些问题都与数据库时区设 置有关。 MySQL Server 中有 2 个环境变量和时区有关,…...

SpringSecurity Context 中 获取 和 更改 当前用户信息的问题

SpringSecurity Context 获取和更改用户信息的问题 SecurityContext 异步线程中获取用户信息 今天在做项目时遇到了一个问题,我需要获取当前用户的 ID。之前,前端并没有存储用户信息,我一直是在后端的 service 中通过 SecurityContext 来获…...

Makefile的四种赋值运算符

Makefile有四种赋值运算符:简单赋值(:)、递归赋值()、条件赋值(?)和追加赋值() 1. 简单赋值(:) 作用:覆盖之前的值。若在多次简单赋…...

framebuffer

framebuffer:帧缓冲、帧缓存 Linux内核为显示提供的一套应用程序接口(驱动内核支持) 分辨率:像素点的总和 像素点: 显示屏:800*600(横向有800个像素点,纵向有600个像素点&#x…...

7.科学计算模块Numpy(4)ndarray数组的常用操作(二)

引言 书接上回,numpy能作为python中最受欢迎的数据处理模块,脱离不了它最核心的部件——ndarray数组。那么,我们今天就来了解一下numpy中对ndarray的常用操作。 通过阅读本篇博客,你可以: 1.掌握ndarray数组的分割 …...

抖音评论区截流脚本软件详细使用教学,抖音私域获客引流的五种方法。

1.先说下什么是抖音截流玩法,截流顾名思义就是在别的博主的视频下面去截流评论潜在流量,然后用评论文案的形式或者其它方式吸引用户加我们的私域~ 玩截流一定不是主动去私信别人,这个就不叫截流了,且一个账号私信多了一定会降权和…...

Linux_kernel移植uboot07

一、移植 根据硬件平台的差异,将代码进行少量的修改,修改过后的代码在目标平台上运行起来 移植还需要考虑硬件环境,驱动只需要考虑内核的环境 二、移植内容 1、移植Uboot uboot属于bootloader的一种,还有其他的bootloader&#x…...

Day-04-QFile打开文件的两种方式

一、UI界面设置两个按键&#xff0c;并直接转到槽函数 二、两种代码展示 #include <QFile> #include <QDebug>//此两种方式中调用函数&#xff0c;应包含的头文件void Widget::on_btnReadFile01_clicked()//第一种打开方式 {//1. 打开文件QFile file;file.setFile…...

第三部分:4---进程地址空间

目录 数组的空间分配解析&#xff1a; 物理地址和虚拟地址&#xff1a; 虚拟地址空间&#xff1a; 进程地址空间的本质&#xff1a; 为什么要有进程地址空间&#xff1f; 页表对进程访问内存的检查&#xff1a; 进程地址空间和页表如何关联起来&#xff1f; 进程的独立…...

【Android】程序开发组件—探究Jetpack

引言 Jetpack是一个开发组件工具集&#xff0c;它的主要目的是帮助我们编写出更加简洁的代码&#xff0c;并简化我们的开发过程&#xff0c;在这么多的组件当中&#xff0c;最需要我们关注的其实还是架构组件&#xff0c;接下来就对Jetpack的主要架构组件进行学习&#xff01;…...

pytorch torch.norm函数介绍

torch.norm 函数用于计算张量的范数&#xff08;norm&#xff09;&#xff0c;可以理解为张量的“长度”或“大小”。根据范数的不同类型&#xff0c;它可以衡量不同的张量性质。该函数可以计算 向量 和 矩阵 的多种范数&#xff0c;如 L1范数、L2范数、无穷范数 等。 1. 函数…...

【lc_hot100】刷题心得

链表 二叉树 二叉树相关的题目基本都有个基本的框架&#xff0c;基本框架就是二叉树的四种遍历方法&#xff1a;前序遍历、中序遍历、后序遍历、层序遍历 往往常用的是前序遍历和中序遍历 图 图跟二叉树一样都有自己的的基本框架&#xff0c;基本框架就是图的两种遍历方法&am…...

FANUC 数控 A06B-6058-H227 伺服放大器

‌发那科伺服放大器是一种控制电机的电子装置&#xff0c;属于电机控制系统的一部分&#xff0c;用于将输入信号放大并转换成电动机可以理解的信号&#xff0c;从而实现运动控制和定位。‌ 发那科伺服放大器的主要作用包括&#xff1a; ‌实现运动控制‌&#xff1a;通过控制…...

Python将表格文件中某些列的数据整体向上移动一行

本文介绍基于Python语言&#xff0c;针对一个文件夹下大量的Excel表格文件&#xff0c;对其中的每一个文件加以操作——将其中指定的若干列的数据部分都向上移动一行&#xff0c;并将所有操作完毕的Excel表格文件中的数据加以合并&#xff0c;生成一个新的Excel文件的方法。 首…...

基于YOLOv8的PCB缺陷检测算法,加入一种基于内容引导注意力(CGA)的混合融合方案(一)

&#x1f4a1;&#x1f4a1;&#x1f4a1;本文内容&#xff1a;针对基于YOLOv8的PCB缺陷检测算法进行性能提升&#xff0c;加入各个创新点做验证性试验。 1&#xff09;提出了一种基于内容引导注意力(CGA)的混合融合方案&#xff0c;mAP0.5由原始的0.966提升至0.975 1.PCB缺陷…...

如何在红米手机中恢复已删除的照片?(6 种方式可供选择)

凭借出色的相机和实惠的价格&#xff0c;小米红米系列已成为全球知名品牌。但是&#xff0c;最近有些人抱怨他们在 红米设备上丢失了许多珍贵的图片或视频&#xff0c;并希望弄清楚如何从小米手机恢复已删除的照片。好吧&#xff0c;在小米设备上恢复已删除的视频/照片并不难。…...

嵌入式实时操作系统(RTOS):原理、应用与发展

摘要&#xff1a;本文围绕嵌入式实时操作系统&#xff08;RTOS&#xff09;展开。首先介绍嵌入式系统与实时操作系统的概念&#xff0c;阐述嵌入式 RTOS 的体系结构。接着分析其关键特性&#xff0c;包含任务管理&#xff08;如任务的创建与删除、调度、同步与通信&#xff09;…...

C#里使用位图容器BitArray

由于经常需要操作一些位表示的数据结构,那么就需要采用位图的管理方式。 在C#里就是使用BitArray来管理位图数据结构,这样就比较方便处理。 这个类可以有多种构造函数,可以满足绝大部分的要求。 比如从网络协议里传送过来的字节流,就可以直接写入到里面,就可以直接获取…...

如何在 Kali Linux 上安装 pip3

如何在 Kali Linux 上安装 pip3 在 Kali Linux 上安装 pip3 的过程非常简单。按照以下步骤&#xff0c;你可以轻松完成安装并开始使用 pip3 管理 Python 软件包。 步骤 1&#xff1a;打开终端 首先&#xff0c;打开你的 Kali Linux 终端。 步骤 2&#xff1a;更新软件包列表…...

5.2 排列与代数余子式

一、求行列式的方法 计算机是利用主元计算行列式的。本节介绍其它两种计算行列式的方法。一是 “大公式”&#xff08;big formula&#xff09;&#xff0c;它使用了全部 n ! n! n! 个排列计算&#xff1b;二是 “代数余子式公式”&#xff08;cofactor formula&#xff09;&…...

工业相机+Python视觉系统崩溃频发?(产线停机损失超¥8600/小时的5个隐藏代码陷阱)

第一章&#xff1a;工业相机视觉系统崩溃的根源诊断工业相机视觉系统在产线部署中一旦突发崩溃&#xff0c;往往表现为图像丢失、帧率归零、设备离线或软件进程异常终止。此类故障表面随机&#xff0c;实则多由底层软硬件协同失配引发&#xff0c;需从驱动层、通信协议、资源调…...

电子元器件检测数据集VOC+YOLO格式1032张5类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件)图片数量(jpg文件个数)&#xff1a;1032标注数量(xml文件个数)&#xff1a;1032标注数量(txt文件个数)&#xff1a;1032标注类别…...

【独家首发】Polars 2.0 vs Pandas 2.2清洗基准测试:10亿行CSV清洗仅耗11.3秒?真相在此

第一章&#xff1a;Polars 2.0大规模数据清洗的范式跃迁Polars 2.0 不再是 Pandas 的轻量替代品&#xff0c;而是一次面向现代硬件与真实业务场景的数据处理范式重构。其核心跃迁体现在零拷贝内存布局、全链路惰性执行引擎&#xff08;LazyFrame&#xff09;与原生支持的并行流…...

在WSL2 Ubuntu 22.04上搞定RK3568 SDK编译:我遇到的8个坑和填坑方法

在WSL2 Ubuntu 22.04上搞定RK3568 SDK编译&#xff1a;我遇到的8个坑和填坑方法 作为一名长期在Windows环境下工作的嵌入式开发者&#xff0c;第一次尝试在WSL2中编译RK3568 SDK的经历简直像是一场噩梦。从环境配置到最终构建成功&#xff0c;我踩遍了几乎所有可能的坑。这篇文…...

python-flask-djangol框架的膳食营养食谱管理系统

目录需求分析技术选型数据库设计核心功能实现界面设计测试与部署维护与扩展项目技术支持源码获取详细视频演示 &#xff1a;文章底部获取博主联系方式&#xff01;同行可合作需求分析 膳食营养食谱管理系统需要具备用户管理、食谱管理、营养分析、购物清单生成等功能。系统应支…...

制造业生产管理应用搭建指南:轻流无代码平台完整实施流程——生产效率提升 300% 方法论

制造业生产管理应用搭建指南&#xff1a;轻流无代码平台完整实施流程——生产效率提升 300% 方法论制造业生产管理应用搭建指南&#xff1a;轻流无代码平台完整实施流程——生产效率提升 300% 方法论引言&#xff1a;背景与重要性工信部《智能制造发展规划》明确提出&#xff0…...

别再让PowerBI报告挤成一团了!用按钮+书签,一个页面搞定趋势和明细分析

PowerBI交互设计进阶&#xff1a;用按钮与书签打造空间魔术 当业务分析报告遇上数据爆炸时代&#xff0c;信息过载与界面拥挤成为每个分析师挥之不去的噩梦。我曾见过某零售企业的季度分析仪表板——12个图表密密麻麻挤在A4纸大小的画布上&#xff0c;趋势线相互缠绕&#xff…...

Qwen3.5-4B-Claude-Opus推理模型基础教程:Temperature/Top-P参数详解

Qwen3.5-4B-Claude-Opus推理模型基础教程&#xff1a;Temperature/Top-P参数详解 1. 模型概述 Qwen3.5-4B-Claude-4.6-Opus-Reasoning-Distilled-GGUF是一个基于Qwen3.5-4B的推理蒸馏模型&#xff0c;特别强化了结构化分析、分步骤回答以及代码与逻辑类问题的处理能力。该模型…...

2026年上海网站建设市场分析:企业官网从展示到增长的演进路径

2026年&#xff0c;上海企业数字化服务市场迎来结构性变革。据2026年上半年上海企业数字化服务市场调研数据显示&#xff0c;上海地区企业官网新建与升级需求同比增长45%&#xff0c;中大型企业对官网的核心诉求已从基础信息展示转向AI智能赋能、全球化跨境适配、全链路营销转化…...

3分钟破解微信小程序加密包:wxappUnpacker极速解析实战指南

3分钟破解微信小程序加密包&#xff1a;wxappUnpacker极速解析实战指南 【免费下载链接】wxappUnpacker 项目地址: https://gitcode.com/gh_mirrors/wxappu/wxappUnpacker wxappUnpacker是一款专注于微信小程序逆向解析的开源工具&#xff0c;能够快速破解wxapkg格式(微…...