国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:130日期:2023-02-18 16:43:08
目錄
  • MYSQL TIMESTAMP字段進行時間加減運算
  • 計算公式如下
  • DATETIME 與 TIMESTAMP的區(qū)別
  • 結(jié)論
  • 參考文檔

MYSQL TIMESTAMP字段進行時間加減運算

在數(shù)據(jù)分析過程中,想當然地對TIMESTAMP字段進行運算,導致結(jié)果謬之千里

計算公式如下

-- create_time與week_time的聲明都是TIMESTAMP(), 要求精確到分鐘 --
SELECT (sa.create_time - sa.week_time)/(1000 * 60)
from alarm_sla_1 sa

當然正確的解法是利用timestampdiff函數(shù),如下:

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

但有意思的問題在于,MYSQL明明支持減法操作,為何操作的結(jié)果又大相徑庭?

類似的問題還有,TIMESTAMP字段的時間精度是什么?

從MYSQL的官方實例中可以看到(請見后續(xù)的參考文檔),TIMESTAMP字段的小數(shù)部分確定了秒的經(jīng)度,3位小數(shù)精確到毫秒,6位小數(shù)精確到微秒,如下:

聲明方式小數(shù)長度精度TIMESTAMP(3)3毫秒TIMESTAMP(6)6微秒

按照上面的推論,那么默認的聲明TIMESTAMP應該精確到秒,那么應該相減的結(jié)果應該得到秒,測試語句如下:

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

但最后的結(jié)果見下表:

相減結(jié)果函數(shù)結(jié)果100001286412

顯然,并不存在相關(guān)性,差異何止里計?

后來繼續(xù)進行了指定經(jīng)度的操作運算,結(jié)論依舊如此。

DATETIME 與 TIMESTAMP的區(qū)別

特性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(秒的精度)格式轉(zhuǎn)換不支持支持UTC多時區(qū)支持不支持,固定時區(qū)不支持創(chuàng)建索引不能能查詢后緩存結(jié)果否是

結(jié)論

MYSQL中TIMESTAMP字段直接進行相減操作,可能得到難以理解的結(jié)果,請慎用。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持。

參考文檔

  • 日期與時間函數(shù)
  • 秒的精度說明
標簽: MySQL
主站蜘蛛池模板: 国产日本亚洲欧美 | 亚洲国产成人久久综合碰 | 久久精品国产亚洲欧美 | 性刺激久久久久久久久 | 免费看欧美一级特黄a大片一 | 91精品国产91久久久久 | 成年片免费网址网站 | 亚洲国产欧美在线人成 | 亚洲韩国欧美一区二区三区 | 亚洲国产精品久久久天堂 | 手机看片日韩日韩国产在线看 | 亚洲精品乱无伦码 | 一级视频在线免费观看 | 亚洲成年网站在线观看 | 男人的天堂久久香蕉国产 | 在线播放一区二区三区 | 亚洲精品久久99久久一区 | 亚洲国产精品91 | 日韩国产在线观看 | 久久99国产精品一区二区 | 中文字幕一区二区在线视频 | 插美女网站 | 午夜宅宅宅影院在线观看 | 99精品免费在线 | 99re9精品视频在线 | vvvv99日韩精品亚洲 | 亚洲最大免费视频网 | 波多野结衣一区在线观看 | 在线精品国产一区二区 | 91久国产在线观看 | 欧美日本一区二区三区生 | 欧美一及片 | 黄色三级在线 | 精品国产成人a区在线观看 精品国产成人a在线观看 | 97在线视频免费播放 | 欧美人一级淫片a免费播放 欧美人与z0z0xxxx | 蕾丝视频永久在线入口香蕉 | 精品无码久久久久久国产 | 久久国产一片免费观看 | 亚洲在线视频观看 | 日韩美毛片 |