日期和时间类函数

介绍了Oracle11g中处理日期和时间的常用函数,包括获取系统当前日期的SYSDATE()函数及计算指定月份后的日期的ADD_MONTHS()函数,并通过实例展示了如何使用这些函数。

在Oracle 11g中,系统提供了许多用于处理日期和时间的函数,通过这些函数可以实现计算需要的特定日期和时间,常用的日期和时间函数如表7.3所示。
表7.3常用日期时间类函数
日期和时间类函数
日期类型的默认格式是“日-月-年”即“DD-MON-YY”,其中“DD”表示两位数字的“日”,MON表示3位数字的“月份”。YY表示两位数字的“年份”,例如,“01-10月-11”表示2011年10月1日。下面看几个常用函数的具体应用。

1.SYSDATE()函数
如果想要系统当前的日期,可以使用SYSDATE()函数,代码如下。

selectsysdateas系统日期from dual;

通过SQL Developer输入,查询结果如图7.14所示。
日期和时间类函数
图7.14 获得系统当前的日期

2.ADD_MONTHS(d,i)函数
该函数返回日期d加上i个月之后的结果。其中,i为任意整数。

实例10 使用ADD_MONTHS()函数计算日期值

使用ADD_MONTHS()函数计算三个月之后的日期和三个月之前的日期,代码如下:

01  selectsysdate当前日期,
02  ADD_MONTHS(sysdate,3) 三个月之后的日期,
03  ADD_MONTHS(sysdate,-3) 三个月之后的日期
04  from dual; 

通过SQL Developer输入,查询结果如图7.15所示。
日期和时间类函数
图7.15 使用ADD_MONTHS()函数计算日期值

通过图7.15可知,当前日期为“2017年5月13日”,那么三个月之前的日期就是“2017年8月13日”。如果ADD_MONTHS()函数的第二个参数为负数,则表明计算的是当前日期之前的日期值。
常见错误:使用“日期 + 数字”的形式来计算之前或之后的日期。
如果要计算三个月之后的日期,使用“sysdate + 90”也是表示三个月之后的日期,为什么要使用ADD_MONTHS()函数来计算日期值呢?
这是因为在日期中存在闰年的情况,如果使用日期加减数字的方式则无法进行准确的日期操作。

转载于:https://blog.51cto.com/13423192/2065362

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值