亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

使用MYSQL TIMESTAMP字段進行時間加減運算問題

瀏覽:89日期:2023-02-18 16:43:08
目錄
  • MYSQL TIMESTAMP字段進行時間加減運算
  • 計算公式如下
  • DATETIME 與 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
主站蜘蛛池模板: 在线精品国产 | 亚洲视频在线精品 | 4388免费特色视频 | 出a级黑粗大硬长爽猛视频 加勒比一道本综合 | 日韩欧美在线视频观看 | 日产国产精品久久久久久 | 日本一级毛片在线看 | 欧美在线一级视频 | 亚洲国产成人精品91久久久 | 日韩国产| 国产精品三 | 直接看黄的网站 | 成人网视频免费播放 | 欧美日韩在线高清 | 一区二区网站在线观看 | 国产一级三级三级在线视 | 91免费小视频 | 91福利视频免费 | 一级视频在线 | 国产精品免费观看视频 | 国产精品免费精品自在线观看 | 国产成人精品在线 | 99久久久久国产精品免费 | 综合久久91| 亚洲女精品一区二区三区 | 国产成人精品三区 | 免费一级特黄视频 | 一级做a免费视频观看网站 一级做a爰毛片 | 国产乱人视频在线看 | 欧美亚洲国产精品久久蜜芽 | 1300部小u女视频免费 | 亚洲精品九色在线网站 | 欧美一级高清黄图片 | 国产网曝手机视频在线观看 | 华人黄网站大全 | 成年免费大片黄在看 | 亚洲欧美日韩高清专区一区 | 在线观看 日韩 | 欧美视频一区二区三区在线观看 | 手机看片久久高清国产日韩 | 欧美性色黄大片a级毛片视频 |