-- Start

我们都知道数字可以进行加、减、乘、除等运算。那么,日期可不可以呢?答案是,日期只能进行加、减运算。

在开始操作日期之前,我们先了解一下 Oracle 支持哪些日期数据类型,如下所示:

  1. DATE
  2. TIMESTAMP
  3. TIMESTAMP WITH TIME ZONE
  4. TIMESTAMP WITH LOCAL TIME ZONE
  5. INTERVAL DAY TO SECOND
  6. INTERVAL YEAR TO MONTH

下面,我们先看一个简单的例子吧,如下所示:

  1. select SYSDATE + INTERVAL '1' DAY, SYSDATE - INTERVAL '2' DAY from dual;
  2. select SYSTIMESTAMP + INTERVAL '1' DAY, SYSTIMESTAMP - INTERVAL '2' DAY from dual;

如上所示,我们可以通过给日期加减一个时间间隔来计算日期,下面是更多的例子。

  1. 日期+ 1 年          SYSDATE + INTERVAL '1' YEAR
  2. 日期+ 1 月          SYSDATE + INTERVAL '1' MONTH
  3. 日期+ 1 日          SYSDATE + INTERVAL '1' DAY
  4. 日期+ 1 时          SYSDATE + INTERVAL '1' HOUR
  5. 日期+ 1 分          SYSDATE + INTERVAL '1' MINUTE
  6. 日期+ 1 秒          SYSDATE + INTERVAL '1' SECOND
  7. 日期+ 1 日1 时1 分    SYSDATE + INTERVAL '1 1:1' DAY TO MINUTE

如果计算的是 DATE 类型,我们还可以采用如下的方式。

  1. DATE+ 1 日          SYSDATE + 1
  2. DATE+ 1 时          SYSDATE + 1/(1*24)
  3. DATE+ 1 分          SYSDATE + 1/(1*24*60)
  4. DATE+ 1 秒          SYSDATE + 1/(1*24*60*60)
  5. DATE+ 1 日1 时1 分    SYSDATE + 1 + 1/(1*24) + 1/(1*24*60)

有时候,我们需要知道两个日期之间相隔多少天,也就是说求日期之间的时间间隔,该怎么办呢?我们很自然的想到把两个日期相减,如下所示:

  1. select (date '2015-04-10' - date '2014-03-11') from dual
  2. select (date '2015-04-10' - date '2014-03-11') YEAR TO MONTH from dual
  3. select (date '2015-04-10' - date '2014-03-11') DAY(3) TO SECOND from dual
  4. select (timestamp '2015-04-10 14:52:19.000' - timestamp '2014-03-11 13:55:29.000') from dual
  5. select (timestamp '2015-04-10 14:52:19.000' - timestamp '2014-03-11 13:55:29.000') YEAR TO MONTH from dual
  6. select (timestamp '2015-04-10 14:52:19.000' - timestamp '2014-03-11 13:55:29.000') DAY(3) TO SECOND from dual

一旦得到了时间间隔,我们就可以通过 EXTRACT 函数抽出时间间隔的组成部分。

  1. select EXTRACT(YEAR FROM (date '2015-04-10' - date '2014-03-11') YEAR TO MONTH) from dual
  2. select EXTRACT(MONTH FROM (date '2015-04-10' - date '2014-03-11') YEAR TO MONTH) from dual
  3. select EXTRACT(DAY FROM (date '2015-04-10' - date '2014-03-11') DAY(3) TO SECOND) from dual

我们还可以抽出以下部分。

  1. YEAR
  2. MONTH
  3. DAY
  4. HOUR
  5. MINUTE
  6. SECOND
  7. TIMEZONE_HOUR
  8. TIMEZONE_MINUTE
  9. TIMEZONE_REGION
  10. TIMEZONE_ABBR

-- 更多参见:Oracle SQL 精萃

-- 声明:转载请注明出处

-- Last edited on 2015-06-19

-- Created by ShangBo on 2015-03-10

-- End

Oracle 日期加减运算的更多相关文章

  1. 类型:Oracle;问题:oracle 时间加减;结果:ORACLE 日期加减操作

    ORACLE 日期加减操作 无论是DATE还是timestamp都可以进行加减操作. 可以对当前日期加年.月.日.时.分.秒,操作不同的时间类型,有三种方法: 1 使用内置函数numtodsinter ...

  2. JAVA日期加减运算

    1.用java.util.Calender来实现 Calendar calendar=Calendar.getInstance();      calendar.setTime(new Date()) ...

  3. ORACLE日期加减【转】

    首先,感谢这个作者的辛勤汗水给我们带来的总结,因为日期函数操作对平时的使用真的是很常用,所以收藏一下以作后期使用. 原贴地址:http://www.cnblogs.com/xiao-yu/archiv ...

  4. ORACLE 日期加减操作

    无论是DATE还是timestamp都可以进行加减操作. 可以对当前日期加年.月.日.时.分.秒,操作不同的时间类型,有三种方法: 1 使用内置函数numtodsinterval增加小时,分钟和秒2 ...

  5. mysql日期加减运算

    MySQL 日期类型MySQL 日期类型:日期格式.所占存储空间.日期范围 比较. 日期类型        存储空间       日期格式                 日期范围 --------- ...

  6. Java对日期Date类进行日期加减运算,年份加减,月份加减

    package com.cy; import java.security.InvalidParameterException; import java.text.ParseException; imp ...

  7. shell 日期加减运算

    比如今日是2012-04-22 $ date -d "+1 day" +%Y-%m-%d 2012-04-23   $ date -d "-1 day" +%Y ...

  8. shell 日期加减

    shell 日期加减运算   比如今日是2012-04-22 $ date -d "+1 day" +%Y-%m-%d 2012-04-23   $ date -d "- ...

  9. Linux中日期的加减运算

    Linux中日期的加减运算 目录 在显示方面 在设定时间方面 时间的加减 正文 date命令本身提供了日期的加减运算. date 可以用来显示或设定系统的日期与时间. 回到顶部 在显示方面 使用者可以 ...

随机推荐

  1. Linux多线程及线程同步简单实例

    一.多线程基本概念 1. 线程的基本概念 ① 线程就是轻量级的进程 ②线程和创建他的进程共享代码段.数据段 ③线程拥有自己的栈 2. 在实际应用中,多个线程往往会访问同一数据或资源,为避免线程之间相互 ...

  2. 匿名类与lambda区别

    第一种是继承Thread, 重写了Thread.run()    getClass()返回的是匿名类 java.long.Thread$1 第二种是lambda, 重写了Runnable.run()  ...

  3. Excel中,用CONCATENATE函数生成SQL语句

    1.语法 CONCATENATE(text1, [text2], ...)CONCATENATE 函数语法具有下列参数(参数为:操作.事件.方法.属性.函数或过程提供信息的值.):Text1 必需.要 ...

  4. GO WEB

    1.第一个坑的就是,错误信息如下: 比较常见的错误“Connection reset by peer”,该错误和“Connection reset”是有区别的: 服务器返回了“RST”时,如果此时客户 ...

  5. C++中遇到的各种小问题

    lpcwstr类型问题 在使用VS2010开发C++程序时,由于系统默认字符集是unicode字符集,造成与早期的字符串格式不兼容问题 ①Properties — Configuration Prop ...

  6. SSM项目spring配置文件详细步骤(分门别类、灵巧记忆)

    spring-dao.xml文件 1.配置外部db.property文件: <context:property-placeholder location="classpath:jdbc ...

  7. mac 下安装 mysql

    1. 下载mysql community server 2. 下载mysql workbench 3. 启动mysql server 4. 进入mysql命令行 5. 修改root密码 ALTER U ...

  8. 牛客网Java刷题知识点之File对象常用功能:获取文件名称、获取文件路径、获取文件大小、获取文件修改时间、创建与删除、判断、重命名、查看系统根目录、容量获取、获取某个目录下内容、过滤器

    不多说,直接上干货! 获取文件名称.获取文件路径.获取文件大小.获取文件修改时间 FileMethodDemo.java package zhouls.bigdata.DataFeatureSelec ...

  9. 牛客网Java刷题知识点之父类中的私有内容,子类是否具备? 子类不可直接,但可间接访问父类中的私有内容?

    不多说,直接上干货!  父类中的私有内容,子类是否具备? 答:不具备 子类不可直接,但可间接访问父类中的私有内容 这样情况,开发中不所见,但是,面试的时候,必考非常常见.

  10. java多线程通过管道流实现不同线程之间的通信

    java中的管道流(pipeStream)是一种特殊的流,用于在不同线程间直接传送数据.一个线程发送数据到输出管道,另外一个线程从输入管道中读取数据.通过使用管道,实现不同线程间的通信,而不必借助类似 ...