#DATE_ADD

date_add
DATE_ADD ( expr , INTERVAL interval_value interval_unit )

DATE_ADD函数用于执行日期运算,对expr的值按给定的区间值将时间前进或者后退。

expr

通用表达式,expr的值须为DATE、TIME、TIMESTAMP类型,或可以转换为DATE、TIMESTAMP类型的字符类型。

当expr为字面量时,只能为DATE和TMIESTAMP关键字的输入字符串,不能为TIME关键字的输入字符串。例如,DATE '2012-10-12'、TIMESTAMP '2012-10-12 10:20:24.000006'为函数可接受的expr值,而当expr为TIME '10:20:24'时函数则返回错误。

当expr为NULL时,函数返回NULL。

interval_value

指定时间前进或后退的区间值,该值不可为NULL,且必须为如下形式:

  • 0或正整数字面量,如0、1、2等。
  • 包含0或正整数内容的字符串字面量,如'0'、'1'、'-2'等。
  • 包含负整数内容的字符串字面量,如'-1'、'-2'等。
  • 包含INTERVAL内容的字符串字面量,如'10-8'、'-8 8:10:24'等。

interval_unit

指定区间值的单位,该值不可为NULL,且必须为如下形式:

  • MONTH、YEAR、YEAR TO MONTH关键字(不区分大小写):此时interval_value被转换为INTERVAL YEAR TO MONTH类型。
  • SECOND、MINUTE、HOUR、DAY、MINUTE TO SECOND、HOUR TO SECOND、HOUR TO MINUTE、DAY TO SECOND、DAY TO MINUTE、DAY TO HOUR关键字(不区分大小写):此时interval_value被转换为INTERVAL DAY TO SECOND类型。

interval_value与interval_unit必须正确匹配,例如分别为2/YEAR,3/HOUR,'10-8'/YEAR TO MONTH、'-8 8:10:24'/DAY TO SECOND,否则函数返回类型转换错误。

日期运算规则

1.当interval_value为INTERVAL YEAR TO MONTH类型时,运算规则为:

  • 先进行month的增减,再看day是否符合month的增减后的day数。
  • 如果增减后的month的天数小于增减前的month的天数,那么增减后的day数等于增减后的month的最后一天。

2.当expr和interval_value的数据类型不相同时,函数先执行类型转换,若两个数据类型之间无法按照一定的规则进行转换,则返回类型转换错误。类型转换规则如下:

  • expr为DATE/TIME/TIMESTAMP类型时,函数返回expr的数据类型。
  • expr为CHAR/VARCHAR类型时,函数先将其能转换为DATE、TIME、TIMESTAMP数据类型中的一种,转换成功则返回转换后的数据类型,否则返回类型转换错误。
  • expr为TIME,interval_value为INTERVAL DAY TO SECOND类型时,超过范围将翻转,即超过24小时求余数,例如计算后的小时为25时,将其翻转为1。
  • expr为TIME,interval_value为INTERVAL YEAR TO MONTH类型时,函数返回类型不支持错误。

示例

SELECT DATE_ADD('2012-10-12',INTERVAL  '-1' YEAR) res FROM DUAL;
RES                                                              
---------------------------------------------------------------- 
2011-10-12 00:00:00.000000  

--interval_value为INTERVAL YEAR TO MONTH类型时
SELECT DATE_ADD('2012-10-31',INTERVAL 1 MONTH) res FROM DUAL;
RES                                                              
---------------------------------------------------------------- 
2012-11-30 00:00:00.000000  

--interval_value为INTERVAL DAY TO SECOND类型时
SELECT DATE_ADD(CAST('10:20:24' AS TIME),INTERVAL '8:10:24' HOUR TO SECOND) res FROM DUAL;
RES                  
-------------------- 
18:30:48.000000 

--小时翻转
SELECT DATE_ADD(CAST('10:20:24' AS TIME),INTERVAL '14:10:24' HOUR TO SECOND) res FROM DUAL;
RES                  
-------------------- 
00:30:48.000000 
pdf-btn 下载文档
copy-btn 复制链接