zoukankan      html  css  js  c++  java
  • 【Oracle】【21】计算两个日期间隔的天数、月数和年数

    正文:

    (1)天数

    两个日期直接相减

    --Oracle中两个日期相差天数--
    select TO_NUMBER(TO_DATE('2018-6-5','yyyy-mm-dd hh24:mi:ss')- TO_DATE('2018-5-31','yyyy-mm-dd hh24:mi:ss')) from dual;
    -- 5

    (2)月数

    要用到months_between函数

    -- Oracle两个日期的相差月数 --
    --1)月份都是最后一天,A日期 > B日期 ,返回整数 ---
    select months_between(TO_DATE('2018-6-30','yyyy-mm-dd hh24:mi:ss'),TO_DATE('2018-5-31','yyyy-mm-dd hh24:mi:ss'))  from dual;
    -- 1
    
    --2)月份都是最后一天,B日期 > A日期 ,返回负数 ---
    select months_between(TO_DATE('2018-4-30','yyyy-mm-dd hh24:mi:ss'),TO_DATE('2018-5-31','yyyy-mm-dd hh24:mi:ss')) from dual;
    -- -1
    
    --3)月份天数不一样,A日期 > B日期 ,返回带小数的数字---
    select months_between(TO_DATE('2018-6-25','yyyy-mm-dd hh24:mi:ss'),TO_DATE('2018-5-31','yyyy-mm-dd hh24:mi:ss')) from dual;
    -- 0.8064516...

    (3)其他:秒数,分种数,小时数,年数

    直接复用上面两种方法即可

    -- Oracle中两个日期相差小时数 --
    select TO_NUMBER((TO_DATE('2018-6-5','yyyy-mm-dd hh24:mi:ss')- TO_DATE('2018-5-31','yyyy-mm-dd hh24:mi:ss'))*24) from dual;
    -- 得到:120
    
    -- Oracle中两个日期相差分钟数 --
    select TO_NUMBER((TO_DATE('2018-6-5','yyyy-mm-dd hh24:mi:ss')- TO_DATE('2018-5-31','yyyy-mm-dd hh24:mi:ss'))*24*60) from dual;
    -- 得到:7200
    
    -- Oracle中两个日期相差秒数 --
    select TO_NUMBER((TO_DATE('2018-6-5','yyyy-mm-dd hh24:mi:ss')- TO_DATE('2018-5-31','yyyy-mm-dd hh24:mi:ss'))*24*60*60) from dual;
    -- 得到:43200
    
    -- Oracle两个日期的相差年份 --
    select ((months_between(TO_DATE('2018-5-31','yyyy-mm-dd hh24:mi:ss'),TO_DATE('2016-5-31','yyyy-mm-dd hh24:mi:ss')))/12) from dual;
    -- 得到:2

    参考博客:

    oracle中计算两个日期的相差天数、月数、年数、小时数、分钟数、秒数等 - 小小邪 - 博客园
    https://www.cnblogs.com/xielong/p/9122254.html

  • 相关阅读:
    Linux基础文件打包
    Linux基础文件查找
    Apache的三种工作模式及相关配置
    elasticsearch启动错误整理
    Zabbix-agentd错误整理
    Nginx编译安装
    PHP编译安装
    Zabbix编译安装(全)
    Chetsheet: 2017 01.01 ~ 01.31
    Cheatsheet: 2016 12.01 ~ 12.31
  • 原文地址:https://www.cnblogs.com/huashengweilong/p/10991791.html
Copyright © 2011-2022 走看看