使用MYSQL TIMESTAMP字段进行时间加减运算问题

 更新时间:2023年02月06日 10:02:22   作者:蚁方阵  
这篇文章主要介绍了使用MYSQL TIMESTAMP字段进行时间加减运算问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

MYSQL TIMESTAMP字段进行时间加减运算

在数据分析过程中,想当然地对TIMESTAMP字段进行运算,导致结果谬之千里

计算公式如下

-- create_time与week_time的声明都是TIMESTAMP(), 要求精确到分钟 --
SELECT (sa.create_time - sa.week_time)/(1000 * 60)
from alarm_sla_1 sa

当然正确的解法是利用timestampdiff函数,如下:

SELECT timestampdiff(minute, sa.create_time, sa.week_time)
from alarm_sla_1 sa

但有意思的问题在于,MYSQL明明支持减法操作,为何操作的结果又大相径庭?

类似的问题还有,TIMESTAMP字段的时间精度是什么?

从MYSQL的官方实例中可以看到(请见后续的参考文档),TIMESTAMP字段的小数部分确定了秒的经度,3位小数精确到毫秒,6位小数精确到微秒,如下:

声明方式小数长度精度
TIMESTAMP(3)3毫秒
TIMESTAMP(6)6微秒

按照上面的推论,那么默认的声明TIMESTAMP应该精确到秒,那么应该相减的结果应该得到秒,测试语句如下:

SELECT sa.week_time - sa.create_time, timestampdiff(second, sa.create_time, sa.week_time)
from alarm_sla_1 sa

但最后的结果见下表:

相减结果函数结果
100001286412

显然,并不存在相关性,差异何止里计?

后来继续进行了指定经度的操作运算,结论依旧如此。

DATETIME 与 TIMESTAMP的区别

特性DATETIMETIMESTAMP
时间范围1000-01-01 00:00:00到9999-12-31 23:59:591970-01-01 00:00:01到2038-01-09 03:14:07
存储空间8+3(秒的精度)4+3(秒的精度)
格式转换不支持支持UTC
多时区支持不支持,固定时区不支持
创建索引不能
查询后缓存结果

结论

MYSQL中TIMESTAMP字段直接进行相减操作,可能得到难以理解的结果,请慎用。

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

参考文档

相关文章

  • MySQL主从配置学习笔记

    MySQL主从配置学习笔记

    在本篇文章里小编给大家整理的是关于MySQL主从配置学习笔记相关内容,需要的朋友们可以学习下。
    2020-03-03
  • mysql 动态执行存储过程语句

    mysql 动态执行存储过程语句

    MSSQL中动态执行sql语句可以使用EXEC()函数。MSSQL中也有类似的函数EXECUTE(),不过不同的是MYSQL中动态执行存储过程语句与MSSQL还是有区别的。
    2009-07-07
  • MySQL在Centos7环境安装的完整步骤记录

    MySQL在Centos7环境安装的完整步骤记录

    在CentOS7环境下安装MySQL是一项常见的任务,尤其对于那些没有网络连接或者需要在隔离环境中的开发者来说,离线安装MySQL显得尤为重要,这篇文章主要介绍了MySQL在Centos7环境安装的完整步骤,需要的朋友可以参考下
    2024-10-10
  • mysql8.0.20配合binlog2sql的配置和简单备份恢复的步骤详解

    mysql8.0.20配合binlog2sql的配置和简单备份恢复的步骤详解

    这篇文章主要介绍了mysql8.0.20配合binlog2sql的配置和简单备份恢复的步骤,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • 坑人的Mysql5.7问题(默认不支持Group By语句)

    坑人的Mysql5.7问题(默认不支持Group By语句)

    这篇文章主要介绍了坑人的Mysql5.7问题(默认不支持Group By语句),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • mysql批量新增和存储的方法实例

    mysql批量新增和存储的方法实例

    这篇文章主要给大家介绍了关于mysql批量新增和存储的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • macOS Sierra安装Apache2.4+PHP7.0+MySQL5.7.16

    macOS Sierra安装Apache2.4+PHP7.0+MySQL5.7.16

    这篇文章主要为大家详细介绍了macOS Sierra安装Apache2.4+PHP7.0+MySQL5.7.16的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • MySQL 5.5主从同步设置笔记分享

    MySQL 5.5主从同步设置笔记分享

    这篇文章主要介绍了MySQL 5.5主从同步设置笔记分享,需要的朋友可以参考下
    2014-05-05
  • mysql中整数数据类型tinyint详解

    mysql中整数数据类型tinyint详解

    大家好,本篇文章主要讲的是mysql中整数数据类型tinyint详解,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12
  • MySQL 行锁和表锁的含义及区别详解

    MySQL 行锁和表锁的含义及区别详解

    这篇文章主要介绍了MySQL 行锁和表锁的含义及区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08

最新评论