mysql 時間類型 字段(精確到時分秒) 怎么比較?
問題描述
我需要根據(jù)create_time字段來篩選數(shù)據(jù),現(xiàn)在sql 語句如下:
SELECT * FROM `sbhf_alarm` sa WHEREunix_timestamp(sa.create_time) BETWEEN unix_timestamp(’2016-05-25 14:07:56’)AND unix_timestamp(’2017-05-25 14:07:56’)
但是,我發(fā)現(xiàn)這種方法由個bug, 就是,當(dāng)上限時間(上圖箭頭)過大的時候,會報錯。如下圖:
原因是,unix_timestamp函數(shù),將時間轉(zhuǎn)化為秒,時間不能太大。
問題:是否還有其他什么更好的方法來篩選時間? 這種問題一般是怎么解決的?請大神賜教,感激不盡……
問題解答
回答1:UNIX_TIMESTAMP返回的是INTEGER而不是BIGINT,所以不能超過2038年(又一說2106年)。
為什么不試試 create_time BETWEEN ’2016-05-25 14:07:56 AND ’2017-05-25 14:07:56’ 呢?
另外,如果追求計算的便捷性,建議時間列類型設(shè)為BIGINT,存放以毫秒為單位的Unix時間戳,這樣就不會有2038問題了。
回答2:create_time BETWEEN ’2016-05-25 14:07:56’ AND ’2017-05-25 14:07:56’
如果加上毫秒的話,注意用冒號:,
create_time BETWEEN ’2016-05-25 14:07:56:000’ AND ’2017-05-25 14:07:56:000’
相關(guān)文章:
1. 請教使用PDO連接MSSQL數(shù)據(jù)庫插入是亂碼問題?2. node.js - nodejs開發(fā)中常用的連接mysql的庫3. Python爬蟲如何爬取span和span中間的內(nèi)容并分別存入字典里?4. mysql - 分庫分表、分區(qū)、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處5. 視頻文件不能播放,怎么辦?6. python - 數(shù)據(jù)與循環(huán)次數(shù)對應(yīng)不上7. mysql - 把一個表中的數(shù)據(jù)count更新到另一個表里?8. 黑客 - Python模塊安全權(quán)限9. flask - python web中如何共享登錄狀態(tài)?10. mysql 查詢身份證號字段值有效的數(shù)據(jù)
