程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 基於mysql時光處置函數的運用詳解

基於mysql時光處置函數的運用詳解

編輯:MySQL綜合教程

基於mysql時光處置函數的運用詳解。本站提示廣大學習愛好者:(基於mysql時光處置函數的運用詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是基於mysql時光處置函數的運用詳解正文


DAYOFWEEK(date)

前往日期date的禮拜索引(1=禮拜天,2=禮拜一, ……7=禮拜六)。這些索引值對應於ODBC尺度。 
mysql> select DAYOFWEEK('1998-02-03'); 
-> 3 

WEEKDAY(date) 
前往date的禮拜索引(0=禮拜一,1=禮拜二, ……6= 禮拜天)。 
mysql> select WEEKDAY('1997-10-04 22:23:00'); 
-> 5 
mysql> select WEEKDAY('1997-11-05'); 
-> 2 

DAYOFMONTH(date) 
前往date的月份中日期,在1到31規模內。 
mysql> select DAYOFMONTH('1998-02-03'); 
-> 3 

DAYOFYEAR(date) 
前往date在一年中的日數, 在1到366規模內。 
mysql> select DAYOFYEAR('1998-02-03'); 
-> 34 

MONTH(date)
前往date的月份,規模1到12。 
mysql> select MONTH('1998-02-03'); 
-> 2 

DAYNAME(date)
前往date的禮拜名字。 
mysql> select DAYNAME("1998-02-05"); 
-> 'Thursday' 

MONTHNAME(date) 
前往date的月份名字。 
mysql> select MONTHNAME("1998-02-05"); 
-> 'February' 

QUARTER(date)
前往date一年中的季度,規模1到4。 
mysql> select QUARTER('98-04-01'); 
-> 2 

WEEK(date) 
  
WEEK(date,first)
關於禮拜天是一周的第一天的處所,有一個單個參數,前往date的周數,規模在0到52。2個參數情勢WEEK()許可
你指定禮拜能否開端於禮拜天或禮拜一。假如第二個參數是0,禮拜從禮拜天開端,假如第二個參數是1,
從禮拜一開端。 
mysql> select WEEK('1998-02-20'); 
-> 7 
mysql> select WEEK('1998-02-20',0); 
-> 7 
mysql> select WEEK('1998-02-20',1); 
-> 8 

YEAR(date) 
前往date的年份,規模在1000到9999。 
mysql> select YEAR('98-02-03'); 
-> 1998 

HOUR(time) 
前往time的小時,規模是0到23。 
mysql> select HOUR('10:05:03'); 
-> 10 

MINUTE(time)
前往time的分鐘,規模是0到59。 
mysql> select MINUTE('98-02-03 10:05:03'); 
-> 5 

SECOND(time)
回來time的秒數,規模是0到59。 
mysql> select SECOND('10:05:03'); 
-> 3 

PERIOD_ADD(P,N) 
增長N個月到階段P(以格局YYMM或YYYYMM)。以格局YYYYMM前往值。留意階段參數P不是日期值。 
mysql> select PERIOD_ADD(9801,2); 
-> 199803 

PERIOD_DIFF(P1,P2) 
前往在時代P1和P2之間月數,P1和P2應當以格局YYMM或YYYYMM。留意,時代參數P1和P2不是日期值。 
mysql> select PERIOD_DIFF(9802,199703); 
-> 11 

DATE_ADD(date,INTERVAL expr type)
  
DATE_SUB(date,INTERVAL expr type)
  
ADDDATE(date,INTERVAL expr type) 
  
SUBDATE(date,INTERVAL expr type) 
這些功效履行日期運算。關於MySQL 3.22,他們是新的。ADDDATE()和SUBDATE()是DATE_ADD()和DATE_SUB()的同義詞。
在MySQL 3.23中,你可使用+和-而不是DATE_ADD()和DATE_SUB()。(見例子)date是一個指定開端日期的
DATETIME或DATE值,expr是指定加到開端日期或從開端日期減去的距離值一個表達式,expr是一個字符串;它可以以
一個“-”開端表現負距離。type是一個症結詞,指明表達式應當若何被說明。EXTRACT(type FROM date)函數從日期
中前往“type”距離。下表顯示了type和expr參數如何被聯系關系: type值 寄義 希冀的expr格局 
SECOND 秒 SECONDS 
MINUTE 分鐘 MINUTES 
HOUR 時光 HOURS 
DAY 天 DAYS 
MONTH 月 MONTHS 
YEAR 年 YEARS 
MINUTE_SECOND 分鐘和秒 "MINUTES:SECONDS" 
HOUR_MINUTE 小時和分鐘 "HOURS:MINUTES" 
DAY_HOUR 天和小時 "DAYS HOURS" 
YEAR_MONTH 年和月 "YEARS-MONTHS" 
HOUR_SECOND 小時, 分鐘, "HOURS:MINUTES:SECONDS" 
DAY_MINUTE 天, 小時, 分鐘 "DAYS HOURS:MINUTES" 
DAY_SECOND 天, 小時, 分鐘, 秒 "DAYS HOURS:MINUTES:SECONDS" 

MySQL在expr格局中許可任何標點分隔符。表現顯示的是建議的分隔符。假如date參數是一個DATE值而且你的盤算僅僅
包括YEAR、MONTH和DAY部門(即,沒有時光部門),成果是一個DATE值。不然成果是一個DATETIME值。 

mysql> SELECT "1997-12-31 23:59:59" + INTERVAL 1 SECOND; 
-> 1998-01-01 00:00:00 
mysql> SELECT INTERVAL 1 DAY + "1997-12-31"; 
-> 1998-01-01 
mysql> SELECT "1998-01-01" - INTERVAL 1 SECOND; 
-> 1997-12-31 23:59:59 
mysql> SELECT DATE_ADD("1997-12-31 23:59:59", 
INTERVAL 1 SECOND); 
-> 1998-01-01 00:00:00 
mysql> SELECT DATE_ADD("1997-12-31 23:59:59", 
INTERVAL 1 DAY); 
-> 1998-01-01 23:59:59 
mysql> SELECT DATE_ADD("1997-12-31 23:59:59", 
INTERVAL "1:1" MINUTE_SECOND); 
-> 1998-01-01 00:01:00 
mysql> SELECT DATE_SUB("1998-01-01 00:00:00", 
INTERVAL "1 1:1:1" DAY_SECOND); 
-> 1997-12-30 22:58:59 
mysql> SELECT DATE_ADD("1998-01-01 00:00:00", 
INTERVAL "-1 10" DAY_HOUR); 
-> 1997-12-30 14:00:00 
mysql> SELECT DATE_SUB("1998-01-02", INTERVAL 31 DAY); 
-> 1997-12-02 
mysql> SELECT EXTRACT(YEAR FROM "1999-07-02"); 
-> 1999 
mysql> SELECT EXTRACT(YEAR_MONTH FROM "1999-07-02 01:02:03"); 
-> 199907 
mysql> SELECT EXTRACT(DAY_MINUTE FROM "1999-07-02 01:02:03"); 
-> 20102 

假如你指定太短的距離值(不包含type症結詞希冀的距離部門),MySQL假定你免卻了距離值的最左臉部分。例如,
假如你指定一個type是DAY_SECOND,值expr被願望有天、小時、分鐘和秒部門。假如你象"1:10"如許指定值,
MySQL假定日子和小時部門是喪失的而且值代表分鐘和秒。換句話說,"1:10" DAY_SECOND以它等價於"1:10" MINUTE_SECOND
的方法說明,這對那MySQL說明TIME值表現經由的時光而非作為一天的時光的方法有二義性。假如你應用確切不准確的日期,
成果是NULL。假如你增長MONTH、YEAR_MONTH或YEAR而且成果日期年夜於新月份的最年夜值天數,日子在新月用最年夜的天調劑。 

mysql> select DATE_ADD('1998-01-30', Interval 1 month); 
-> 1998-02-28 

留意,早年面的例子中詞INTERVAL和type症結詞不是辨別年夜小寫的。 
TO_DAYS(date) 
給出一個日期date,前往一個天數(從0年的天數)。 
mysql> select TO_DAYS(950501); 
-> 728779 
mysql> select TO_DAYS('1997-10-07'); 
-> 729669 

TO_DAYS()不盤算用於應用格列高裡歷(1582)湧現前的值。 

FROM_DAYS(N)
給出一個天數N,前往一個DATE值。 
mysql> select FROM_DAYS(729669); 
-> '1997-10-07' 

TO_DAYS()

不盤算用於應用格列高裡歷(1582)湧現前的值。 

DATE_FORMAT(date,format)
依據format字符串格局化date值。以下潤飾符可以被用在format字符串中: %M 月名字(January……December) 
%W 禮拜名字(Sunday……Saturday) 
%D 有英語前綴的月份的日期(1st, 2nd, 3rd, 等等。) 
%Y 年, 數字, 4 位 
%y 年, 數字, 2 位 
%a 縮寫的禮拜名字(Sun……Sat) 
%d 月份中的天數, 數字(00……31) 
%e 月份中的天數, 數字(0……31) 
%m 月, 數字(01……12) 
%c 月, 數字(1……12) 
%b 縮寫的月份名字(Jan……Dec) 
%j 一年中的天數(001……366) 
%H 小時(00……23) 
%k 小時(0……23) 
%h 小時(01……12) 
%I 小時(01……12) 
%l 小時(1……12) 
%i 分鐘, 數字(00……59) 
%r 時光,12 小時(hh:mm:ss [AP]M) 
%T 時光,24 小時(hh:mm:ss) 
%S 秒(00……59) 
%s 秒(00……59) 
%p AM或PM 
%w 一個禮拜中的天數(0=Sunday ……6=Saturday ) 
%U 禮拜(0……52), 這裡禮拜天是禮拜的第一天 
%u 禮拜(0……52), 這裡禮拜一是禮拜的第一天 
%% 一個文字“%”。 

一切的其他字符不做說明被復制到成果中。 

mysql> select DATE_FORMAT('1997-10-04 22:23:00', '%W %M %Y'); 
-> 'Saturday October 1997' 
mysql> select DATE_FORMAT('1997-10-04 22:23:00', '%H:%i:%s'); 
-> '22:23:00' 
mysql> select DATE_FORMAT('1997-10-04 22:23:00', 
'%D %y %a %d %m %b %j'); 
-> '4th 97 Sat 04 10 Oct 277' 
mysql> select DATE_FORMAT('1997-10-04 22:23:00', 
'%H %k %I %r %T %S %w'); 
-> '22 22 10 10:23:00 PM 22:23:00 00 6' 
MySQL3.23中,在格局潤飾符字符前須要%。在MySQL更早的版本中,%是可選的。 

TIME_FORMAT(time,format)
這象下面的DATE_FORMAT()函數一樣應用,然則format字符串只能包括處置小時、分鐘和秒的那些格局潤飾符。
其他潤飾符發生一個NULL值或0。

CURDATE() 
  
CURRENT_DATE 
以'YYYY-MM-DD'或YYYYMMDD格局前往明天日期值,取決於函數是在一個字符串照樣數字高低文被應用。 
mysql> select CURDATE(); 
-> '1997-12-15' 
mysql> select CURDATE() + 0; 
-> 19971215 

CURTIME() 
  
CURRENT_TIME 
以'HH:MM:SS'或HHMMSS格局前往以後時光值,取決於函數是在一個字符串照樣在數字的高低文被應用。 
mysql> select CURTIME(); 
-> '23:50:26' 
mysql> select CURTIME() + 0; 
-> 235026 

NOW()
  
SYSDATE() 
  
CURRENT_TIMESTAMP 
以'YYYY-MM-DD HH:MM:SS'或YYYYMMDDHHMMSS格局前往以後的日期和時光,取決於函數是在一個字符串照樣在數字的
高低文被應用。 
mysql> select NOW(); 
-> '1997-12-15 23:50:26' 
mysql> select NOW() + 0; 
-> 19971215235026 

UNIX_TIMESTAMP(date) 
假如沒有參數挪用,前往一個Unix時光戳記(從'1970-01-01 00:00:00'GMT開端的秒數)。假如UNIX_TIMESTAMP()用一
個date參數被挪用,它前往從'1970-01-01 00:00:00' GMT開端的秒數值。date可所以一個DATE字符串、一個DATETIME
字符串、一個TIMESTAMP或以YYMMDD或YYYYMMDD格局的當地時光的一個數字。 
mysql> select UNIX_TIMESTAMP(); 
-> 882226357 
mysql> select UNIX_TIMESTAMP('1997-10-04 22:23:00'); 
-> 875996580 

當UNIX_TIMESTAMP被用於一個TIMESTAMP列,函數將直接接收值,沒有隱含的“string-to-unix-timestamp”變換。 

FROM_UNIXTIME(unix_timestamp) 
以'YYYY-MM-DD HH:MM:SS'或YYYYMMDDHHMMSS格局前往unix_timestamp參數所表現的值,取決於函數是在一個字符串
照樣或數字高低文中被應用。 
mysql> select FROM_UNIXTIME(875996580); 
-> '1997-10-04 22:23:00' 
mysql> select FROM_UNIXTIME(875996580) + 0; 
-> 19971004222300 

FROM_UNIXTIME(unix_timestamp,format) 
前往表現 Unix 時光標志的一個字符串,依據format字符串格局化。format可以包括與DATE_FORMAT()函數列出的條
目異樣的潤飾符。 
mysql> select FROM_UNIXTIME(UNIX_TIMESTAMP(), 
'%Y %D %M %h:%i:%s %x'); 
-> '1997 23rd December 03:43:30 x' 

SEC_TO_TIME(seconds) 
前往seconds參數,變換成小時、分鐘和秒,值以'HH:MM:SS'或HHMMSS格局化,取決於函數是在一個字符串照樣在數字
高低文中被應用。 
mysql> select SEC_TO_TIME(2378); 
-> '00:39:38' 
mysql> select SEC_TO_TIME(2378) + 0; 
-> 3938 

TIME_TO_SEC(time) 
前往time參數,轉換成秒。 
mysql> select TIME_TO_SEC('22:23:00'); 
-> 80580 
mysql> select TIME_TO_SEC('00:39:38'); 
-> 2378

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved