暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

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

西安川石 2020-09-09
274

点击上方蓝字关注我们

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

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

实例:

SELECT ADDDATE("2017-06-15", INTERVAL 10 DAY);

返回结果:2017-06-25


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

实例:

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

返回结果:2011-11-11 11:11:16 ()


CURDATE():返回当前日期     

实例:

SELECT CURDATE();

返回结果: 2018-09-19


CURRENT_DATE():返回当前日期 

实例:

SELECT CURRENT_DATE();

返回结果: 2018-09-19

CURRENT_TIME:返回当前时间     

实例:

SELECT CURRENT_TIME();

返回结果: 19:59:02


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

实例:

SELECT CURRENT_TIMESTAMP();

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


CURTIME():返回当前时间      

实例:

SELECT CURTIME();

返回结果: 19:59:02


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

实例:

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

返回结果: 2017-06-15


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

实例:

SELECT DATEDIFF('2001-01-01','2001-02-02');

返回结果: -32


DATE_ADD(dINTERVAL expr type)      :计算起始日期 d 加上一个时间段后的日期     

实例:

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

返回结果: 2011-11-12 11:11:11    (默认是天)

SELECT ADDDATE('2011-11-11 11:11:11', INTERVAL 5 MINUTE);

返回结果: 2011-11-11 11:16:11 (TYPE的取值与上面那个列出来的函数类似)

DATE_FORMAT(d,f):按表达式 f的要求显示日期 d        

实例:

SELECT DATE_FORMAT('2011-11-11 11:11:11','%Y-%m-%d %r');

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


DATE_SUB(date,INTERVAL expr type):函数从日期减去指定的时间间隔。   

Orders 表中 OrderDate 字段减去 2 天:

实例:

SELECT OrderId,DATE_SUB(OrderDate,INTERVAL 2 DAY) AS OrderPayDate

FROM Orders;


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

实例:

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

返回结果: 15


DAYNAME(d)   :返回日期 d 是星期几,如 Monday,Tuesday        

实例:

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

返回结果:Friday

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

实例:

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

返回结果:11


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

实例:

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

返回结果:6


DAYOFYEAR(d):计算日期 d 是本年的第几天        

实例:

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

返回结果:315


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

实例:

SELECT FROM_DAYS(1111);

返回结果: 0003-01-16


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

实例:

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

返回结果: 1


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

实例:

SELECT LAST_DAY("2017-06-20");

返回结果: 2017-06-30


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

实例:

SELECT LOCALTIME();

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


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

实例:

SELECT LOCALTIMESTAMP();

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

MAKEDATE(year, day-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(date):返回日期参数所对应的微秒数    

实例:

SELECT MICROSECOND("2017-06-20 09:34:00.000023");

返回结果: 23


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

实例:

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

返回结果: 2


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

实例:

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

返回结果: November


MONTH(d):返回日期d中的月份值, 12

实例:

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

返回结果:11


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

实例:

SELECT NOW();

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

PERIOD_ADD(period, number):为 - 组合日期添加一个时段 

实例:

SELECT PERIOD_ADD(201703, 5);  

返回结果: 201708


PERIOD_DIFF(period1, period2):返回两个时段之间的月份差值     

实例:

SELECT PERIOD_DIFF(201710, 201703);

返回结果: 7


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

实例:

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

返回结果: 4


SECOND(t):返回 t 中的秒钟值      

实例:

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

返回结果: 3


SEC_TO_TIME(s):将以秒为单位的时间 s 转换为时分秒的格式     

实例:

SELECT SEC_TO_TIME(4320);

返回结果: 01:12:00


STR_TO_DATE(string, format_mask):将字符串转变为日期 

实例:

SELECT STR_TO_DATE("August 10 2017", "%M %d %Y");

返回结果: 2017-08-10


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

实例:

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

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


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

实例:

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

返回结果:2011-11-11 11:11:06 ()


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

实例:

SELECT SYSDATE();

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


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

实例:

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

返回结果: 19:30:10


TIME_FORMAT(t,f):按表达式 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');

返回结果: 4320


TIMEDIFF(time1, time2):计算时间差值  

实例:

SELECT TIMEDIFF("13:10:11", "13:10:10");

返回结果: 00:00:01


TIMESTAMP(expression, interval):单个参数时,函数返回日期或日期时间表达式;有2个参数时,将参数加和     

实例:

SELECT TIMESTAMP("2017-07-23",  "13:10:11");

返回结果: 2017-07-23 13:10:11

TO_DAYS(d):计算日期 d 距离 0000  1  1 日的天数   

实例:

SELECT TO_DAYS('0001-01-01 01:01:01');

返回结果: 366


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

实例:

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

返回结果: 45


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

实例:

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

返回结果: 3


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

实例:

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

返回结果: 45


YEAR(d):返回年份

实例:

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

返回结果: 2017


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

实例:

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

返回结果: 201724


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



西安校区

软件测试入门到高薪全程班,9月15号开课,免费试学!


扫码下面二维码进入软件测试QQ交流群哦~

扫下方二维码进入腾讯课堂体验免费课程~

川石最新内推岗位,点击查看下图!



关注我们,川石带你转技术!


戳这里,阅读原文
文章转载自西安川石,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论