Mysql数据库常见函数(下)——日期时间函数

前两期我们分别学习了Mysql数据库中常见的字符函数和数值函数,那么本期我们一起来学习Mysql数据库中常见的日期时间函数。

ADDDATE(d,n):计算起始日期 d 加上 n 天的日期

实例:

SELECT ADDDATE("201r v ] z 0 z 0 l7-06-15", INTERVAL 10 DB } z 1 * & L yAY);

返回结果:2017-06-25! g H , t e t 9

ADDTIME(t,n) :时间 t 加上 n 秒的时间

实例:

SELECT ADDTIME('2011-11-11 11:11:11', 5);

返回结果:2011-11-11 11D } M ; O e:11:16 (秒)

CURDATE():返回当前日期

实例:

SELECT CURDATE();

返回D Y . j @ / J结果: 2018-09-19

CURRENT_DAu T P z ) m zTE():返回当前日期

实例:

SELECT4 f @ 0 k 4 g CURRENT_DATE();

返回结果G Z 1: 2018-09-19

CURRENw ( ] U ? 7 u #T_TIME:返回当前时间

实例:

SELEC) * v T p T TT CO D e c ; bURRENT_TIME();

返回- { K ! ^ R 0结果: 19:59:02

CURRENT_TIMESTAMP():返回当前日期和时间

实例:

SELECT CURRENT_TIMESTAMP();

返回结果: 2018-09-19 20:57:43

CURTIME():返回当前时间

实例:

SELECT CURTIME();

返回结果: 19:59:02

DATE():从日期或日期时间表达式中提取日期值

实例:

SELECT DATE("2M / b w ] U017-06-15");

返回结果: 2017-06-15

DATEDIFF(d1,d2):计算日期 d1返回结果:d2 之间相隔的天数

实例:

SELECT DATEDIFF('2001-01-01',b i W N Q o }'2001-02-02');

返回结果: -32

DATE_ADD(d,INTERVAL expr type) :计算起始M , M A R R w日期 d 加上一个时间段后的日期

实例:

SELECT ADDDATE('2011-11-11 11:11:11',1);

返回结果:- _ t + G U 4 u 2011-11-12 11:11:11 (默认是天)

S- ! # q *ELECT ADDDATE('2011-11-11 11:11:11', INTERVAL 5 MINUTE);

返回结果: 2011-11-1u f R / x C Z P R1N z ~ 1S t Y 21:16:11 (TV 8 P } ~ ( H 8YPE的取值与上面那个列出来的函数似)

DATE= 9 p_FORMAT(d,f):按表达] K i Y f的要求显示日期 d

实例:

SELECT DATE_FORMAT('z 4 3 @ I p2011-11-11 11:11:11','%Y-%m-%d %r');

返回结果: 2011-11-11 11:11:11 AM

DATE_R 3 { j 2 ; + J bSUB(date,INTERVAL exG g Gpr type):函数从日期减去指定的时间间隔。

Orders 表中 OrderDate 字段减去/ u o B D 2 天:

实例:

SELECT O ` a o prderId,DATE_SUB(Orderu 1 g oDate,INTERVAL 2B y w Q DAY) AS OrderPayDate

FROM Orders;

DAY(d):返回日期值 d 的日期部分

实例:

SELECT DAY("2{ H M h j 3 * R |017-06-15");

返回结果: 15

DAYNAME(d) :返回日} b B 1 t $ 8 !期 d 是星期几,如 Monday,Tuesday

实例:

SELECT DAYNAME(a l C &'2011-11-11 11:11:11');

返回结果:Friday

DAYOFMONTH(d) :计算日期 d 是本月的第几天

实例:

SELECT DAYOFMONTH('2011-11-11 11:1W 2 # U R N1:11');

返回结果:11

DAYOFWEEK(d):日期 d 今天是星期几,1 星期日,2 星期一,以此

实例:

SELECT DAYOFWEEK('2011-11-111 + r n ? F k c 11:11:11');

返回结果:6

DAYOFYEA p nAR(d):计算日期 d 是本年的第几天

实例:

SELECT DAYOFYEAR('2011-11-11 11:11:11');

返回结果:315

FROM_DAYS(n):计算从 0000 年 1 月 1 日开始 n 天后的日期

实例:

SELECT FROM_DAYS(1111);

返回I 9 B @ R X J结果: 0003-01-16

HOUR(t) :返回 t 中的小时值

实例:

SELECT HOUR('1:2:3');

返回结果: 1

LAST_DAY(d) :返回给给定日期的那一月份的最后一天

实例:

SF N y z Y : o C ?ELECT LAST_DAY("2017-06-20");

返回结果: 2017-06-30

LOCALTIME() :返回当前日期和时间

实例:

SELECT LOCALTIME();

返回结果: 2018-09-19 20:57:43

LOCALTIMESTAMP():返回当前日期和时间

实例:

SELECT LOCALTIMESTAMP();

返回结果: 2) ? O018-09-19 20:57:S e 3 & # B V C `43

MAKEDATE(year, day` R h ! 3 i A 6-of-year):基于给定参数年份 year 和所在年中的天数序号 day-of-year 返回一个日期

实例:

SELECT MAKEDATE(2017, 3);

返回结果: 2017-01-03

MAKETIME(hour, minute, second):组合时间,参数分别为小时、分钟、秒

实例:

SELECT MAKETIME(11, 35, 4);

返回结果: 11:35:04

MICROSECOND(E [ x qdate):返回日期参数所对应的微秒数

实例:

SELECT MICROSECOND("2017-06-20 09:3W F h 4 O k4:00.000023");

返回结果: 23

MINUTE(t):返回 t 中1 U |的分钟值

实例:

SELECT MINUTE('1:2:3');;

返回结果: 2

MONTHNAME(d):返回日期当中的月份名称,如 November

实例:

SELECT MONTHNAME('2011-11-11 1^ V B : | +1:11:11');

返回结果: November

MONTl b ? % nH(d):返回日期d中的月份值,1 到 12

实例. ~ Q ( [ o

SELECT MONTH('2011-11-11 11:11:11');

返回结果:11

NOW():返回当前日期和时间

L q 7 V +例:

SELECT NOW();

返回结果: 2018z M g n g-09-19 20:57:43

PERIOD_ADD(period, number)s 5 B o 6 J l:为 年-月 组合日期添加一个时段

实例:

SELECT PERIOD_ADD(2017, u o R 6 4 n03, 5);

返回结果: 201708

PERIOD_DIFF(period1, period4 F Q2):返回两9 y B E , 5 ~ 8 y个时段之间的月份差值

实例:

SELECT PERIOD_DIFF(201710, 201703);

返回结果: 7

QUARTER(d):返回日期d是第几季节,返回 1 到 4

实例:

SELECT QUARTER('2011-11$ | B F 9 E j T-11 11:11:11'Y p Z ~ O ]);

返回结果: 4

SECOND(t):返回 t 中的秒钟W b # ` O g ,

实例:

SELECT SECOND('1:2:3');

返回结果: 3

SEC_TO_TIME(s):将k S + ? 9 L k I S n X z秒为单位的时间 s 转换为时分秒的格式

实例:[ Q - }

SELECT SEC_TO_TIME(4320);

返回结果: 01:12:00

STR_TO_DATE(string, format_mask):将字符串转@ q B , L ` G ;变为日期

实例:

SELECT _ [ $ # ` Z 6 ` STR_TO_DATE("August 10 2017", "i s Q : N ( U%M %d %Y");

返回结果: 2017-08-10

SUBDATE(d,n):日期 d 减去 n- p H 天后的日期

实例:

SELECT SUBDATE('2011-11-11 11:11:11', 1);

返回0 c M结果:2011-11-10 11:11:11 (默认是天)

SUBTIME(t,n):时间 t 减去 n 秒的时间

实例:

SELECT SUBTIME('2011-& h C x z11-11 11:11:11', 5);

返回结果:2@ ] 9 @ M = } ?011-11-| 9 K e j 6 c11 11:11:06 (秒)

SYSDATE():返回当前日期和时间

实例:

SELECT SYSDATE();

返回结果: 2018-09-19 20:57:43

TIME(expression):提取传入表达式的时间部分

实例:

SELECT TIME("19:30:10");

返回结果: 19:30:10

TI@ = # x 4ME_FORMAT(t,f7 : } l):按表达式 f 的要求显示时间 t

实例:

SELECT TIME_FORMAT('11:11:11','%r');

返回结果:11:11:11 AM

TIME_TO_SEC(t):将时间 t 转换为秒

实例:

SELECT TIME_TO_SEC('1:12:00');

返回结果| z v V / W u $: 4320

TIMEL ) w C k ]DIFF(time1, time2):计算时间差值

实例:

SELECT TIMEDIFF("13:10:11", "13:10:10");? e | 2 F ? }

返回结果: 00:00:01

TIMESTAMP(expr+ ! 8 A Oession, interval):单个参数时,/ b / } G - 0 Z w函数返回日期或日期时间表达式;有2个参数时,将参数加和

实例:

SELEC5 7 $ E 5 ] H ` 3T TIM` @ dESTAs e w f g ? B )M{ 4 l h W t 4 %P("2017-07-23", "13:10:11");L h % f

返回结果: 2017-07-( ; * S C 423 13:10:11t q 3 g

TO_DAYS(d):计算日期 d 距离 0000 年 1 月/ v # ! e ; 9 _ P 1 日的天数

实例:

SELECT TO_DAYS('0001-01-01 01:e s * } 01:01');

返回结果: 366

WEEK(d) :计算日期 d 是本年的第几个星期,范围是 0 到 53

实例:

SELECT WEEK('2011-11-11 11:11:11');

返回结果: 45

WEEKDAY(d) :日期 d 是星期几,0 表示星期一,1 表示星期二

实例:

SELECT WEEKDAY("2017-06-15");

返回结果: 3

WEEKOFYEAR(d) :计算日期 d 是本年的第几个星期,范围是 0 到 53

实例:

SELECT WEEKOFYEAR('2011-11-11 11:11:11');

返回结果: 45

YEAR(d& Y G p b):返回年份

实例:

SELECT YEAR("2017-06-15");

返回结果: 2017

YEARWEEK(date, mode):返回年份及第几周(0到53),mode 中 0 表示周天,1表示周一,以此类推

实例:

SELECT YEARWEEK("2017-06-15");

返回1 t - a J & ? 3结果: 201724

学到这里我们Mysql数C 2 r据库常见函数就告一段落了,更多Mysql数据[ J z库知识等你来学习,我们下期见哦。

PS:获取更多资料,私信我哦~