mysql linux 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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值