文章詳情頁
使用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ù)精確到微秒,如下:
按照上面的推論,那么默認的聲明TIMESTAMP應該精確到秒,那么應該相減的結(jié)果應該得到秒,測試語句如下:
SELECT sa.week_time - sa.create_time, timestampdiff(second, sa.create_time, sa.week_time) from alarm_sla_1 sa
但最后的結(jié)果見下表:
顯然,并不存在相關(guān)性,差異何止里計?
后來繼續(xù)進行了指定經(jīng)度的操作運算,結(jié)論依舊如此。
DATETIME 與 TIMESTAMP的區(qū)別
結(jié)論
MYSQL中TIMESTAMP字段直接進行相減操作,可能得到難以理解的結(jié)果,請慎用。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持。
參考文檔
- 日期與時間函數(shù)
- 秒的精度說明
標簽:
MySQL
排行榜
