mysql更新到5.6.4 之後 , 新增了一個叫factional seconds的特性 , 可以記錄時間的毫秒值。但目前的資料庫是不記錄毫秒值的 , 所以會產生一個java中時間的Milliseconds超過500就會四捨五入的問題。
下面是一個例子,示範了時間是如何進位的。首先建立一張表:
CREATE TABLE test_time ( time_sec datetime, time_millis datetime(3), time_micros datetime(6), stamp_sec timestamp, stamp_millis timestamp(3), stamp_micros timestamp(6) );
有的小夥伴可能不知道 datetime 和 timestamp 定義時是可以帶精確度的,精確度值為 0~6,表示保留幾位小數,預設值為 0。顯然保留 3 位元可看作精度為毫秒,保留 6 位元可看作精度為微秒。
(線上學習影片教學推薦:mysql影片教學)
然後我們插入一筆記錄:
INSERT INTO test_time ( time_sec, time_millis, time_micros, stamp_sec, stamp_millis, stamp_micros ) VALUES( '2019-11-30 12:34:56.987654', '2019-11-30 12:34:56.987654', '2019-11-30 12:34:56.987654', '2019-11-30 12:34:56.987654', '2019-11-30 12:34:56.987654', '2019-11-30 12:34:56.987654' );
然後再做一次 select * from test_time 查詢就能看到下面的結果:
time_sec |time_millis |time_micros |stamp_sec |stamp_millis |stamp_micros | ---------------------|-----------------------|--------------------------|---------------------|-----------------------|--------------------------| 2019-11-30 12:34:57.0|2019-11-30 12:34:56.988|2019-11-30 12:34:56.987654|2019-11-30 12:34:57.0|2019-11-30 12:34:56.988|2019-11-30 12:34:56.987654|
可以看到time_sec 和stamp_sec 在資料庫中的秒值都被進位了,time_millis 和stamp_millis 的毫秒值都被進位了。
由此可見,要避免這樣的誤差,有兩個手段:
1、定義欄位的時候使用datetime(6) 或timestamp(6);
2、定義欄位時不帶精確度,但在將時間存入資料庫之前,要將毫秒值截取掉。
相關文章教學推薦:mysql教學
#以上是關於mysql中的時間進位問題的講解的詳細內容。更多資訊請關注PHP中文網其他相關文章!