關於Oracle計算日期間隔天數

最近要計算日期間隔天數,測試發現幾個問題,剛開始搜網友的,有些不太靠譜。
1、首先日期不能相加。
2、如果要相減,最好去掉時分秒,格式化成年月日,直接相減的話得到的是小數,日期相減底層應該是操作的毫秒級,都帶時分秒的,這樣算天數的時候會精確到時分秒算,特別是用了sysdate,上午和下午執行的天數結果是不一樣的。建議用trunc格式一下。

關於round和trunc函數,round會四捨五入,已中午12點爲判斷;trunc只截取當天。(第二個參數都是默認情況下)比如:

select round(to_date('2019-04-12 11:23:33','yyyy-MM-dd HH24:mi:ss')) from dual
2019-04-12 00:00:00
select round(to_date('2019-04-12 12:23:33','yyyy-MM-dd HH24:mi:ss')) from dual
2019-04-13 00:00:00
select round(to_date('2019-04-14 13:23:33','yyyy-MM-dd HH24:mi:ss'))-round(to_date('2019-04-12 10:23:33','yyyy-MM-dd HH24:mi:ss')) num from dual
3
select trunc(to_date('2019-04-12 11:23:33','yyyy-MM-dd HH24:mi:ss')) from dual;
2019-04-12 00:00:00
select trunc(to_date('2019-04-12 12:23:33','yyyy-MM-dd HH24:mi:ss')) from dual;
2019-04-12 00:00:00
select trunc(to_date('2019-04-14 13:23:33','yyyy-MM-dd HH24:mi:ss'))-round(to_date('2019-04-12 10:23:33','yyyy-MM-dd HH24:mi:ss')) num from dual;
2
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章