关于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
  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值