我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

使用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字段直接进行相减操作,可能得到难以理解的结果,请慎用。

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

参考文档

  • 日期与时间函数
  • 秒的精度说明

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

目录mysql TIMESTAMP字段进行时间加减运算计算公式如下DATETIMEjavascript 与 TIMESTAMP的区别结论参考文档MYSQL TIMESTAMP字段进行时间加减运算在数据分析过程中,想当然地对TIMESTAM
2023-02-06

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

这篇文章主要介绍了使用MYSQLTIMESTAMP字段进行时间加减运算问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-02-06

MySQL如何使用加法和减法运算符进行日期运算?

MySQL 可以通过将 INTERVAL 关键字与时间单位、日期或日期时间相加来使用加法和减法运算符执行日期算术。示例 1将 2 天添加到特定日期.mysql> Select 2017-05-20 + INTERVAL 2 day;+--
2023-10-22

在arcgis使用python脚本进行字段计算时是如何解决中文问题的

一、引言在arcgis打开一个图层的属性表,可以对属性表的某个字段进行计算,但是在平常一般都是使用arcgis提供的字段计算器的界面进行傻瓜式的简答的赋值操作,并没有使用到脚本对字段值进行逻辑的操作。由于最近一直在学python脚本,刚好又
2022-06-04

编程热搜

目录