Mysql數據庫常見函數(下)——日期時間函數


前兩期我們分別學習了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(d,INTERVAL 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 今天是星期幾,1 星期日,2 星期一,以此類推

實例:

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中的月份值,1 到 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 是星期幾,0 表示星期一,1 表示星期二

實例:

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):返回年份及第幾周(0到53),mode 中 0 表示周天,1表示周一,以此類推

實例:

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

返回結果: 201724

學到這里我們Mysql數據庫常見函數就告一段落了,更多Mysql數據庫知識等你來學習,我們下期見哦。

PS:獲取更多資料,私信我哦~


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM