电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

mysql解決時區相關問題

瀏覽:130日期:2023-10-13 12:34:44

前言:

在使用 MySQL 的過程中,你可能會遇到時區相關問題,比如說時間顯示錯誤、時區不是東八區、程序取得的時間和數據庫存儲的時間不一致等等問題。其實,這些問題都與數據庫時區設置有關,本篇文章將從數據庫參數入手,逐步介紹時區相關內容。

1.log_timestamps 參數介紹

首先說明下log_timestamps參數并不影響時區,只是設置不同會影響某些日志記錄的時間。該參數主要是控制 error log、slow log、genera log 日志文件中的顯示時間,但不會影響 general log 和 slow log 寫到表 (mysql.general_log, mysql.slow_log) 中的顯示時間。

log_timestamps 是全局參數,可動態修改,默認使用 UTC 時區,這樣會使得日志中記錄的時間比北京時間慢 8 個小時,導致查看日志不方便。可以修改為 SYSTEM 變成使用系統時區。下面簡單測試下該參數的作用及修改方法:

# 查看參數值mysql> show global variables like ’log_timestamps’;+----------------+-------+| Variable_name | Value |+----------------+-------+| log_timestamps | UTC |+----------------+-------+1 row in set (0.00 sec)# 產生慢日志mysql> select sleep(10),now();+-----------+---------------------+| sleep(10) | now()|+-----------+---------------------+| 0 | 2020-06-24 17:12:40 |+-----------+---------------------+1 row in set (10.00 sec)# 慢日志文件記錄內容 發現時間是UTC時間# Time: 2020-06-24T09:12:50.555348Z# User@Host: root[root] @ localhost [] Id: 10# Query_time: 10.000354 Lock_time: 0.000000 Rows_sent: 1 Rows_examined: 1SET timestamp=1592989960;select sleep(10),now();# 修改參數值 再次測試mysql> set global log_timestamps = SYSTEM;Query OK, 0 rows affected (0.00 sec)mysql> select sleep(10),now();+-----------+---------------------+| sleep(10) | now()|+-----------+---------------------+| 0 | 2020-06-24 17:13:44 |+-----------+---------------------+1 row in set (10.00 sec)# 慢日志文件記錄內容 時間是對的# Time: 2020-06-24T17:13:54.514413+08:00# User@Host: root[root] @ localhost [] Id: 10# Query_time: 10.000214 Lock_time: 0.000000 Rows_sent: 1 Rows_examined: 1SET timestamp=1592990024;select sleep(10),now();

2.time_zone 參數介紹

time_zone參數用來設置每個連接會話的時區,該參數分為全局和會話級別,可以動態修改。默認值為 SYSTEM,此時使用的是全局參數 system_time_zone 的值,而 system_time_zone 默認繼承自當前系統的時區,即默認情況下 MySQL 時區和系統時區相同。

時區設置主要影響時區敏感的時間值的顯示和存儲。包括一些函數(如 now()、curtime())顯示的值,以及存儲在 TIMESTAMP 類型中的值,但不影響 DATE、TIME 和 DATETIME 列中的值,因為這些數據類型在存取時未進行時區轉換,而 TIMESTAMP 類型存入數據庫的實際是 UTC 的時間,查詢顯示時會根據具體的時區來顯示不同的時間。

下面我們來測試下 time_zone 參數修改產生的影響:

# 查看linux系統時間及時區[root@centos ~]# dateSun Jun 28 14:29:10 CST 2020# 查看MySQL當前時區、時間mysql> show global variables like ’%time_zone%’;+------------------+--------+| Variable_name | Value |+------------------+--------+| system_time_zone | CST || time_zone | SYSTEM |+------------------+--------+2 rows in set (0.00 sec)mysql> select now();+---------------------+| now()|+---------------------+| 2020-06-28 14:31:12 |+---------------------+1 row in set (0.00 sec)# 創建測試表、插入部分數據mysql> CREATE TABLE `time_zone_test` ( -> `id` int unsigned NOT NULL AUTO_INCREMENT COMMENT ’自增主鍵’, -> `dt_col` datetime DEFAULT NULL COMMENT ’datetime時間’, -> `ts_col` timestamp DEFAULT NULL COMMENT ’timestamp時間’, -> PRIMARY KEY (`id`) -> ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT=’time_zone測試表’;Query OK, 0 rows affected, 1 warning (0.07 sec)mysql> insert into time_zone_test (dt_col,ts_col) values (’2020-06-01 17:30:00’,’2020-06-01 17:30:00’),(now(),now());Query OK, 2 rows affected (0.01 sec)Records: 2 Duplicates: 0 Warnings: 0mysql> select * from time_zone_test;+----+---------------------+---------------------+| id | dt_col | ts_col |+----+---------------------+---------------------+| 1 | 2020-06-01 17:30:00 | 2020-06-01 17:30:00 || 2 | 2020-06-28 14:34:55 | 2020-06-28 14:34:55 |+----+---------------------+---------------------+# 改為UTC時區 并重新連接 發現timestamp存儲的時間會隨時區變化mysql> set global time_zone=’+0:00’;Query OK, 0 rows affected (0.00 sec)mysql> set time_zone=’+0:00’;Query OK, 0 rows affected (0.00 sec)mysql> show global variables like ’%time_zone%’;+------------------+--------+| Variable_name | Value |+------------------+--------+| system_time_zone | CST || time_zone | +00:00 |+------------------+--------+2 rows in set (0.00 sec)mysql> select now();+---------------------+| now()|+---------------------+| 2020-06-28 06:36:16 |+---------------------+1 row in set (0.00 sec)mysql> select * from time_zone_test;+----+---------------------+---------------------+| id | dt_col | ts_col |+----+---------------------+---------------------+| 1 | 2020-06-01 17:30:00 | 2020-06-01 09:30:00 || 2 | 2020-06-28 14:34:55 | 2020-06-28 06:34:55 |+----+---------------------+---------------------+2 rows in set (0.00 sec)# 改回東八時區,恢復正常mysql> set global time_zone=’+8:00’;Query OK, 0 rows affected (0.00 sec)mysql> set time_zone=’+8:00’;Query OK, 0 rows affected (0.00 sec)mysql> show global variables like ’%time_zone%’;+------------------+--------+| Variable_name | Value |+------------------+--------+| system_time_zone | CST || time_zone | +08:00 |+------------------+--------+2 rows in set (0.00 sec)mysql> select now();+---------------------+| now()|+---------------------+| 2020-06-28 14:39:14 |+---------------------+1 row in set (0.00 sec)mysql> select * from time_zone_test;+----+---------------------+---------------------+| id | dt_col | ts_col |+----+---------------------+---------------------+| 1 | 2020-06-01 17:30:00 | 2020-06-01 17:30:00 || 2 | 2020-06-28 14:34:55 | 2020-06-28 14:34:55 |+----+---------------------+---------------------+2 rows in set (0.00 sec)

如果需要永久生效,還需寫入配置文件中。例如將時區改為東八區,則需要在配置文件[mysqld]部分增加一行:default_time_zone = ’+8:00’。

3.時區常見問題及如何避免

時區設置不妥可能會產生各種問題,下面我們列舉下幾個常見的問題及解決方法:

3.1 MySQL 內部時間不是北京時間

遇到這類問題,首先檢查下系統時間及時區是否正確,然后看下 MySQL 的 time_zone,建議將 time_zone 改為’+8:00’。

3.2 Java 程序存取的時間與數據庫中的時間相差 8 小時

出現此問題的原因大概率是程序時區與數據庫時區不一致導致的。我們可以檢查下兩邊的時區,如果想統一采用北京時間,則可以在 jdbc 連接串中增加 serverTimezone=Asia/Shanghai,并且 MySQL 方面也可以將 time_zone 改為’+8:00’。

3.3 程序時間與數據庫時間相差 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。

3.4 如何避免出現時區問題

如何避免上述時區問題,可能你心里也有了些方法,簡要總結幾點如下:

首先保證系統時區準確。 jdbc 連接串中指定時區,并與數據庫時區一致。 time_zone 參數建議設置為’+8:00’,不使用容易誤解的 CST。 各環境數據庫實例時區參數保持相同。

可能有的同學說了,我們數據庫中 time_zone 參數選擇的是默認的 SYSTEM 值,也沒有發生程序時間和數據庫時間不一致的問題。此時是否需要將 time_zone 改為’+8:00’?在這種情況下還是建議將 time_zone 改為’+8:00’,特別是經常查詢 TIMESTAMP 字段,因為當 time_zone=system 的時候,查詢 timestamp 字段會調用系統的時區做時區轉換,有全局鎖__libc_lock_lock 的保護,可能導致線程并發環境下系統性能受限。而改為’+8:00’則不會觸發系統時區轉換,使用 MySQL 自身轉換,大大提高了性能。

總結:

讀完本篇文章,你是否對數據庫時區有了更深刻的認識呢。希望這篇文章對你有所幫助,特別是想了解 MySQL 時區相關內容時,可以拿來多讀讀。如果你遇到過其他時區相關問題,歡迎留言討論。

以上就是mysql解決時區相關問題的詳細內容,更多關于mysql時區相關問題的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 济南冷库安装-山东冷库设计|建造|冷库维修-山东齐雪制冷设备有限公司 | 撕碎机,撕破机,双轴破碎机-大件垃圾破碎机厂家 | 闸阀_截止阀_止回阀「生产厂家」-上海卡比阀门有限公司 | 北京乾茂兴业科技发展有限公司| 生物制药洁净车间-GMP车间净化工程-食品净化厂房-杭州波涛净化设备工程有限公司 | 明渠式紫外线杀菌器-紫外线消毒器厂家-定州市优威环保 | 壹车网 | 第一时间提供新车_资讯_报价_图片_排行! | 苏州注册公司_苏州代理记账_苏州工商注册_苏州代办公司-恒佳财税 | 高压管道冲洗清洗机_液压剪叉式升降机平台厂家-林君机电 | 安全阀_弹簧式安全阀_美标安全阀_工业冷冻安全阀厂家-中国·阿司米阀门有限公司 | 康明斯发电机,上柴柴油发电机,玉柴柴油发电机组_海南重康电力官网 | 小型气象站_车载气象站_便携气象站-山东风途物联网 | 横河变送器-横河压力变送器-EJA变送器-EJA压力变送器-「泉蕴仪表」 | 纸塑分离机-纸塑分离清洗机设备-压力筛-碎浆机厂家金双联环保 | 【德信自动化】点胶机_全自动点胶机_自动点胶机厂家_塑料热压机_自动螺丝机-深圳市德信自动化设备有限公司 | 手术室净化厂家-成都做医院净化工程的公司-四川华锐-15年特殊科室建设经验 | 电磁铁_小型推拉电磁铁_电磁阀厂家-深圳市宗泰电机有限公司 | 称重传感器,测力传感器,拉压力传感器,压力变送器,扭矩传感器,南京凯基特电气有限公司 | 派财经_聚焦数字经济内容服务平台 | 水环真空泵厂家,2bv真空泵,2be真空泵-淄博真空设备厂 | 没斑啦-专业的祛斑美白嫩肤知识网站-去斑经验分享 | 蒸压釜-陶粒板隔墙板蒸压釜-山东鑫泰鑫智能装备有限公司 | 全国冰箱|空调|洗衣机|热水器|燃气灶维修服务平台-百修家电 | 中红外QCL激光器-其他连续-半导体连续激光器-筱晓光子 | 西子馋火锅鸡加盟-太原市龙城酉鼎餐饮管理有限公司 | 【德信自动化】点胶机_全自动点胶机_自动点胶机厂家_塑料热压机_自动螺丝机-深圳市德信自动化设备有限公司 | 低合金板|安阳低合金板|河南低合金板|高强度板|桥梁板_安阳润兴 北京租车牌|京牌指标租赁|小客车指标出租 | 电采暖锅炉_超低温空气源热泵_空气源热水器-鑫鲁禹电锅炉空气能热泵厂家 | 刘秘书_你身边专业的工作范文写作小秘书 | 无菌实验室规划装修设计-一体化实验室承包-北京洁净净化工程建设施工-北京航天科恩实验室装备工程技术有限公司 | 真石漆,山东真石漆,真石漆厂家,真石漆价格-山东新佳涂料有限公司 | 【化妆品备案】进口化妆品备案流程-深圳美尚美化妆品有限公司 | 水热合成反应釜-防爆高压消解罐-西安常仪仪器设备有限公司 | 广州云仓代发-昊哥云仓专业电商仓储托管外包代发货服务 | 北京企业宣传片拍摄_公司宣传片制作-广告短视频制作_北京宣传片拍摄公司 | UV固化机_UVLED光固化机_UV干燥机生产厂家-上海冠顶公司专业生产UV固化机设备 | 粘度计NDJ-5S,粘度计NDJ-8S,越平水分测定仪-上海右一仪器有限公司 | 航空障碍灯_高中低光强航空障碍灯_民航许可认证航空警示灯厂家-东莞市天翔航天科技有限公司 | 课件导航网_ppt课件_课件模板_课件下载_最新课件资源分享发布平台 | 粉末包装机-给袋式包装机-全自动包装机-颗粒-液体-食品-酱腌菜包装机生产线【润立机械】 | 海南在线 海南一家 |