mysql之关于CST和GMT时区时间转换方式

 更新时间:2023年10月12日 10:02:21   作者:飞廉灬少将  
这篇文章主要介绍了mysql之关于CST和GMT时区时间转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

问题

今天在往数据库查询一条数据时突然发现插入的时间竟然比系统时间少了13个小时。。。

然后因为插入时间的问题延伸出之前写的SQL中只要涉及到创建时间都有可能存在,也就是某月1号插入的数据,你在统计时,当月并未统计,实际上是在上个月的统计数据中。。。。

这就尴尬了。。。

排查

1、首先查证测试环境数据库时区:

SHOW VARIABLES LIKE ‘%time_zone%'

竟然设置的CST时区,之前不是啊,之后询问主管才得知,当前改造的老项目生产环境的数据库使用的CST。。。

为了保证测试一致性,就修改了数据库时区。。。

到此,直接找到时间相差13个小时的原因。。。。

解决

既然知道时间差,也知道时区了,那么问题就好解决了,

mysql中有一个函数CONVERT_TZ() 可以解决这个问题(这里为了更直观,直接贴图)

通过这条SQL查询出来的时间

SELECT report_id,create_time FROM report_item WHERE report_id=2584

结果:

上图中的时间就是CST时区时间,单实际上系统时间是:2021-05-21 10:05:12,相差足足13个小时

所以SQL修改为:

SELECT report_id,CONVERT_TZ(create_time, 'UTC','+13:00') as create_time FROM report_item WHERE report_id=2584

到这里,基本完美解决了时区转换问题,后来度娘了一下这个问题,发现CST和GMT时间相差是13或14小时,至于是13小时还是14小时,取决于你传递给数据库的时间

函数介绍:CONVERT_TZ(dt,from_tz,to_tz)

转换datetime值dt,从 from_tz 由给定转到 to_tz 时区给出的时区,并返回的结果值。

如果参数无效该函数返回NULL。

示例

yyyy-MM-dd格式

SELECT CONVERT_TZ('2021-5-21 15:30:00','UTC','+13:00') AS 北京时间;

这里注意一点,我的SQL时区是CST,但是我在这里用的UTC来作为标准时间,所以可以理解CST-UTC-GMT,所以最后我用了+13:00,这里也可能会有人问为什么不直接用CST来转,这个嘛。。。

可能是我mysql版本问题?

我直接写CST,竟然返回给我一个null。。。尴尬。。。

使用这样的写法可以解决现在的问题,但是最重要的一点就是从根源上去解决,不要去给数据库设置默认时区,如果一定要,那设置GMT或者UTC都可以,不用使用CST时区,因为这个时区存在很多很多的问题,这里就不意义赘述了。。。

大家可以去找度娘要关于CST时区的问题

总结

1、数据库时区最好不要设置成CST,以免出现上面的错误

2、当数据库中的时间用的是时间类型时候,Java中可以用String,但是这种做法不是很国际化

3、在数据库连接字符串中设置时区。

推荐这种方式,如下:

jdbc:mysql://xxxx:3306/table_name?serverTimezone=Asia/ShanghaiallowMultiQueries=true&useUnicode=true&characterEncoding=UTF-8

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL函数之字符串函数解读

    MySQL函数之字符串函数解读

    MySQL提供了多种字符串函数,如CONCAT、CONCAT_WS、LENGTH、CHAR_LENGTH、LEFT、RIGHT、REPLACE、SUBSTRING、TRIM、FIND_IN_SET和FORMAT,用于处理数据库中的字符串数据
    2024-12-12
  • MySQL取消了Query Cache的原因

    MySQL取消了Query Cache的原因

    这篇文章主要介绍了MySQL取消了Query Cache的原因,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下
    2020-10-10
  • 一篇文章带你入门SQL编程

    一篇文章带你入门SQL编程

    这篇文章主要为大家详细介绍了SQL编程的入门方法,使用数据库,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • MySQL SQL预处理(Prepared)的语法实例与注意事项

    MySQL SQL预处理(Prepared)的语法实例与注意事项

    所谓预编译语句就是将此类SQL语句中的值用占位符替代,可以视为将 SQL语句模板化或者说参数化,一般称这类语句叫Prepared Statements,下面这篇文章主要给大家介绍了关于MySQL SQL预处理(Prepared)的相关资料,需要的朋友可以参考下
    2022-01-01
  • MySQL中count(*)执行慢的解决方案

    MySQL中count(*)执行慢的解决方案

    这篇文章主要介绍了MySQL中count(*)执行慢的解决方案,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-06-06
  • 教你为MySQL数据库换挡加速

    教你为MySQL数据库换挡加速

    如果你是个赛车手,并且按一下按钮就能够立即更换引擎而不需要把车开到车库里去换,那会是什么感觉呢?MySQL数据库为开发人员所做的就好像是按按钮换引擎;它让你选择数据库引擎,并给你一条简单的途径来切换它。
    2010-02-02
  • MySQL报错1067 :Invalid default value for ‘字段名’

    MySQL报错1067 :Invalid default value for&n

    在使用MySQL5.7时,还原数据库的时候报错,下面就来介绍一下MySQL报错1067 :Invalid default value for ‘字段名’,具有一定的参考价值,感兴趣的可以了解一下
    2024-05-05
  • MySQL的savepoint简介及实例

    MySQL的savepoint简介及实例

    MySQL中的保存点Savepoint是一个用于控制事务的重要工具,本文主要介绍了MySQL的savepoint简介及实例,具有一定的参考价值,感兴趣的可以了解一下
    2023-08-08
  • 如何用word vb宏来生成sql

    如何用word vb宏来生成sql

    本篇文章是对利用word vb宏来生成sql的方法进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • MySQL安装提示配置信息已损坏请联系技术人员

    MySQL安装提示配置信息已损坏请联系技术人员

    为了重新安装MySql,看别人的博客说在注册表中搜索mysql,全部删除。再安装时提示配置信息已损坏,遇到这个问题怎么处理呢,下面小编给大家带来了详细解决方法,感兴趣的朋友一起看看吧
    2023-01-01

最新评论