遇到mysql timezone带来数据不一致问题怎么处理
admin
2023-05-18 19:42:22
0

文主要给大家介绍遇到mysql timezone带来数据不一致问题怎么处理,文章内容都是笔者用心摘选和编辑的,具有一定的针对性,对大家的参考意义还是比较大的,下面跟笔者一起了解下遇到mysql timezone带来数据不一致问题怎么处理吧。

mysql> select *,from_unixtime(create_time) from 表名 where source_id=xxx\G
*************************** 1. row ***************************
                        id: xxx
                       uid: xxx
                 source_id: xxx
               create_time: 1495324892
                      type: 0
                  source_status: 0
                 nick_name: 环境监控组-xxx
                start_time: 1495324883
                    remark: 忽略视频
          pre_check_status: 0
                    source: 3
from_unixtime(create_time): 2017-05-21 00:01:32
1 row in set (0.00 sec)

因为运营库是2主2从,我对比了主从的数据,发现确实不一样,一个是早上8点,另外一个是凌晨,使用了from_unixtime函数,结果相差8个小时,比较像是时区的问题

mysql> select from_unixtime(1495324892);
+---------------------------+
| from_unixtime(1495324892) |
+---------------------------+
| 2017-05-21 08:01:32       |
+---------------------------+
1 row in set (0.00 sec)

mysql> select from_unixtime(1495324892);
+---------------------------+
| from_unixtime(1495324892) |
+---------------------------+
| 2017-05-21 00:01:32       |
+---------------------------+
1 row in set (0.00 sec)

怀疑是linux机器的时区问题,但查询发现都是一样的

Thu May 25 15:11:29 CST 2017

既然与linux时区无关,那应该跟MySQL的时间有关了,再次分别查询主从的时间

mysql> select now();
+---------------------+
| now()               |
+---------------------+
| 2017-05-25 15:12:28 |
+---------------------+
1 row in set (0.00 sec)
mysql> select now();
+---------------------+
| now()               |
+---------------------+
| 2017-05-25 07:09:31 |
+---------------------+
1 row in set (0.00 sec)

果然是MySQL的时间问题

mysql> show variables like "%time_zone%";
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone | HKT    |
| time_zone        | SYSTEM |
+------------------+--------+
2 rows in set (0.00 sec)


mysql> show variables like "%time_zone%";
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone | UTC    |
| time_zone        | SYSTEM |
+------------------+--------+
2 rows in set (0.00 sec)

发现一个MySQL处于UTC时间,世界标准时间,而另外一个是香港时间,中国是东八区,比世界标准时间多8个小时,这就解释了为什么8点打卡,却显示在凌晨上班。于是把有问题的MySQL,重新修改时区

set global time_zone = '+8:00';
set time_zone = '+8:00';
flush privileges;

看完以上关于遇到mysql timezone带来数据不一致问题怎么处理,很多读者朋友肯定多少有一定的了解,如需获取更多的行业知识信息 ,可以持续关注我们的行业资讯栏目的。

相关内容

热门资讯

2000万粉丝博主发声:撑不住... 5月14日、15日两天,辽宁本地知名搞笑博主“大连老湿王博文”,分别在微信公众号和小红书上发表长文,...
零食包装也变黑白,死亡氛围在日... 作者 | 荣智慧 编辑 | 向现5月12日,日本“国民零食”巨头卡乐比宣布,因“石脑油”供应短缺,旗...
欧洲首个可复用航天器整装待发,... (来源:科普中国) 转自:科普中国 据阿根廷布宜诺斯艾利斯经济新闻网 5 月 10 日报道,欧洲即将...
奥立电子取得密封型线束专利,降... 国家知识产权局信息显示,东莞奥立电子有限公司取得一项名为“密封型线束”的专利,授权公告号CN2242...
嘉陵江重庆段发生划桨板人员落水... 记者从重庆市相关部门了解到,16日晚,嘉陵江重庆中心城区段发生一起划桨板人员落水事件,有7人落水。事...
自动空调调到多少度合适 冬天,调成30度比较合适的。夏天的时候,空调设置的温度应该比室外温度低3到4度,一般来说,26度是比...
空调制热多少度合适 空调制热多少度合适?从人体舒适方面来考虑,冬季室内温度最好控制在18—20度之间。在这个温度下人是感...
电视机运行内存多大合适 电视机运行内存多大合适:4k电视的运行内存在2GB及以上最好。如今,Android 5.0以上的系统...
iphone13电量 演示机型信息: 品牌型号:iPhone13 系统版本:IOS16.1 iphone13电量最高百分之...
noritz能率热水器维修电话 热水器在我们的日常生活中扮演着重要的角色,为我们提供温暖舒适的热水。然而,由于长时间使用或其他原因,...