日期时间函数的参数至少有一个是日期时间类型(TIME,DATE,TIMESTAMP),返回值一般为日期时间类型和数值类型。由于 DM 支持儒略历,并考虑了历史上从儒略历转换至格里高利日期时的异常,不计算’1582-10-05’到’1582-10-14’之间的 10 天,因此日期时间函数也不计算这 10 天。

函数 ADD_DAYS

语法:ADD_DAYS( date, n)

功能:返回日期 date 加上相应天数 n 后的日期值。n 可以是任意整数,date 是日期
类型(DATE)或时间戳类型(TIMESTAMP),返回值为日期类型(DATE)。
例:

SELECT ADD_DAYS( DATE ‘2000-01-12’,1);
查询结果为:2000-01-13

函数 ADD_MONTHS

语法:ADD_MONTHS(date,n)

功能:返回日期 date 加上 n 个月的日期时间值。n 可以是任意整数,date 是日期类型(DATE)或时间戳类型(TIMESTAMP),返回类型固定为日期类型(DATE)。如果相加之后的结果日期中月份所包含的天数比 date 日期中的日分量要少,那么结果日期的该月最后一天被返回。
例:

SELECT ADD_MONTHS(DATE ‘2000-01-31’,1);
查询结果为:2000-02-29
SELECT ADD_MONTHS(TIMESTAMP ‘2000-01-31 20:00:00’,1);
查询结果为:2000-02-29

函数 ADD_WEEKS

语法:ADD_WEEKS( date, n)

功能:返回日期 date 加上相应星期数 n 后的日期值。n 可以是任意整数,date 是日
期类型(DATE)或时间戳类型(TIMESTAMP),返回类型固定为日期类型(DATE)。
例:

SELECT ADD_WEEKS( DATE ‘2000-01-12’,1);
查询结果为: 2000-01-19

函数 CURDATE

语法:CURDATE()
功能:返回当前日期值,结果类型为 DATE。
例
SELECT CURDATE();
查询结果为:执行此查询当天日期,如 2020-02-27

函数 CURTIME

语法:CURTIME(n)

功能:返回当前时间值,结果类型为 TIME WITH TIME ZONE。
参数:n:指定毫秒的精度。取值范围 0-6,默认为 6。
例:

SELECT CURTIME();
查询结果为:执行此查询的当前时间,如 14:53:54.859000 +8:00

函数 DATEDIFF/BIGDATEDIFF

语法:DATEDIFF(datepart,date1,date2)

功能:返回跨两个指定日期的日期和时间边界数。datepart 取值见表 8.3.1。
注:当结果超出整数值范围,DATEDIFF 产生错误。对于毫秒 MILLISECOND,最大
数是 24 天 20 小时 31 分钟零 23.647 秒。对于秒,最大数是 68 年。若想提高可以
表示的范围,可以使用 BIGDATEDIFF,其使用方法与 DATEDIFF 函数一致,只是可以表
示更广范围的秒和毫秒。
例:

SELECT DATEDIFF(QQ, ‘2003-06-01’, DATE ‘2002-01-01’);
查询结果为:-5
SELECT DATEDIFF(MONTH, ‘2001-06-01’, DATE ‘2002-01-01’);
查询结果为:7
SELECT DATEDIFF(WK, DATE ‘2003-02-07’,DATE ‘2003-02-14’);
查询结果为:1
SELECT DATEDIFF(MS,‘2003-02-14 12:10:10.000’,‘2003-02-14 12:09:09.300’);
查询结果为:-60700

函数 DATEPART/DATE_PART

语法:DATEPART(datepart,date)

功能:返回代表日期 date 的 指 定 部 分 的 整 数 。 datepart 取 值 请 参 考
DATEDIFF(datepart,date1,date2)的参数。
例:

SELECT DATEPART(SECOND, DATETIME ‘2000-02-02 13:33:40.00’);
查询结果为:40
SELECT DATEPART(DY, ‘2000-02-02’);
查询结果为:33
SELECT DATEPART(WEEKDAY, ‘2002-02-02’);
查询结果为:7
说明:日期函数:date_part,其功能与 datepart 完全一样。但是写法有点不同:
select datepart(year,‘2008-10-10’);如果用 date_part,则要写成:select
date_part(‘2008-10-10’,‘year’),即:参数顺序颠倒,同时指定要获取的日期部分
的参数要带引号。

函数 DAY

语法:DAY(date)

功能:返回指定日期在月份中的天数
例:

SELECT DAY(‘2016-06-07’);
查询结果为:7

函数 DAYNAME

语法:DAYNAME(date)

功能:返回日期的星期名称。
例:

SELECT DAYNAME(DATE ‘2012-01-01’);
查询结果为:Sunday

函数 DAYOFMONTH

语法:DAYOFMONTH(date)

功能:返回日期为所处月份中的第几天。
例:

SELECT DAYOFMONTH(‘2003-01-03’);
查询结果为:3

函数 DAYOFWEEK

语法:DAYOFWEEK(date)

功能:返回日期为所处星期中的第几天。

SELECT DAYOFWEEK(‘2003-01-01’);
查询结果为:4

函数 DAYOFYEAR

语法:DAYOFYEAR(date)

功能:返回日期为所处年中的第几天。

SELECT DAYOFYEAR(‘2003-03-03’);
查询结果为:62

函数 DAYS_BETWEEN

语法: DAYS_BETWEEN(dt1,dt2)

功能:返回两个日期之间相差的天数。

函数 GETDATE

语法:GETDATE(n)

功能:返回系统的当前时间戳。
参数:n:指定毫秒的精度。取值范围 0-6,默认为 6。

SELECT GETDATE();
查询结果为:返回系统的当前日期时间,如 2011-12-05 11:31:10.359000

函数 GREATEST

语法:GREATEST(date1,date2,date3)

功能:求 date1、date2 和 date3 中的最大日期。

SELECT GREATEST(date’1999-01-01’,date’1998-01-01’,date’2000-01-01’);
查询结果:2000-01-01

函数 GREAT

语法:GREAT (date1,date2)

功能:求 date1、date2 中的最大日期。

SELECT GREAT (date’1999-01-01’, date’2000-01-01’);
查询结果:2000-01-01

函数 HOUR

语法:HOUR(time)

功能:返回时间中的小时分量。

SELECT HOUR(TIME ‘20:10:16’);
查询结果为:20

LAST_DAY(date)

语法:LAST_DAY(date)

功能:返回 date 所在月最后一天的日期,date 是日期类型(DATE)或时间戳类型
(TIMESTAMP),返回类型与 date 相同。

SELECT LAST_DAY(SYSDATE) “Days Left”;
查询结果为:如:当前日期为 2003 年 2 月的某一天,则结果为 2003-02-28
SELECT LAST_DAY(TIMESTAMP ‘2000-01-11 12:00:00’);
查询结果为:2000-01-31

函数 LEAST

语法:LEAST(date1,date2,date3)

功能:求date1、date2和date3中的最小日期。

SELECT LEAST(date’1999-01-01’,date’1998-01-01’,date’2000-01-01’);
查询结果:1998-01-01

函数 MINUTE

语法:MINUTE(time)

功能:返回时间中的分钟分量。

SELECT MINUTE(‘20:10:16’);
查询结果为:10

函数 MONTH

语法:MONTH(date)

功能:返回日期中的月份分量。

SELECT MONTH(‘2002-11-12’);
查询结果为:11

函数 NOW

语法:NOW(n)

功能:返回系统的当前时间戳。等价于 GETDATE()。
参数:n:指定毫秒的精度。取值范围 0-6,默认为 6。

函数 QUARTER

语法:QUARTER(date)

功能:返回日期在所处年中的季度数。

SELECT QUARTER(‘2002-08-01’);
查询结果为:3

函数 SECOND

语法:SECOND(time)

功能:返回时间中的秒分量。

SELECT SECOND(‘08:10:25.300’);
查询结果为:25

函数 SYSDATE

语法: SYSDATE()

功能: 获取系统当前时间。

SELECT SYSDATE();
查询结果:当前系统时间

函数 WEEK

语法:WEEK(date)

功能:返回指定日期属于所在年中的第几周。

SELECT WEEK(DATE ‘2003-02-10’);
查询结果为:7

函数 WEEKDAY

语法:WEEKDAY(date)

功能:返回指定日期的星期值。如果是星期日则返回 0。

SELECT WEEKDAY(DATE ‘1998-10-26’);
查询结果:1

函数 WEEKS_BETWEEN

语法:WEEKS_BETWEEN(date1,date2)

功能:返回两个日期之间相差周数。

SELECT WEEKS_BETWEEN(DATE ‘1998-2-28’, DATE ‘1998-10-31’);
查询结果:-35

函数 YEAR

语法:YEAR(date)

功能:返回日期中的年分量。

SELECT YEAR(DATE ‘2001-05-12’);
查询结果为:2001

函数 YEARS_BETWEEN

语法:YEARS_BETWEEN(date1,date2)

功能:返回两个日期之间相差年数。

SELECT YEARS_BETWEEN(DATE ‘1998-2-28’, DATE ‘1999-10-31’);
查询结果为: -1

函数 DATE_FORMAT

语法:DATE_FORMAT (d datetime, format varchar)
 功能:以不同的格式显示日期/时间数据。
 参数:
 d:可以是可以是一个 DATETIME、TIME、DATE、timestamp with time zone、
 timestamp with LOCAL time zone 类型(时区忽略,使用当前时区)、一个
 YYYYMMDD YYMMDD YMMDD YYYMMDD 格式的整形(不支持)。 format: 规定日期/时间的输出格式。格式有以下:27 个(NG 表示暂不支持)。

format

释义

备注

%a

缩写星期名

%b

缩写月名

%c

月,数值(0-12)

暂不支持

%D

带有英文前缀的月中的天

%d

月的天,数值(00-31)

%e

月的天,数值(0-31) 暂不支持

%f

微秒

%H

小时 (00-23)

%h

小时 (01-12)

%I

小时 (01-12)

%i

分钟,数值(00-59)

%j

年的天 (001-366)

%k

小时 (0-23)

暂不支持

%l

小时 (1-12)

暂不支持

%M

月名

%m

月,数值(00-12)

%p

AM 或 PM

%r

时间,12-小时(hh:mm:ss AM 或 PM)

%S

秒(00-59)

%s

秒(00-59)

%T

时间, 24-小时 (hh:mm:ss)

%U

周 (00-53) 星期日是一周的第一天

%u

星期(0„„52), 这里星期一是星期的第一天

暂不支持

%W

星期名字(Sunday、Tuesday、Wednesday、Thursday、Friday、Saturday)

%Y

年, 数字, 4 位

%y

年, 数字, 2 位

%%

一个文字“%”

select date_format(timestamp ‘1980-1-1
1:1:1.123456789’,’%Y-%m-%d %H:%i:%s’);
查询结果:1980-01-01 01:01:01

函数 SEC_TO_TIME

语法:SEC_TO_TIME (sec int)

功能:将秒换算成时间

select sec_to_time(104399);
查询结果: 28:59:59