程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> mysql 日期和時光格局轉換完成語句

mysql 日期和時光格局轉換完成語句

編輯:MySQL綜合教程

mysql 日期和時光格局轉換完成語句。本站提示廣大學習愛好者:(mysql 日期和時光格局轉換完成語句)文章只能為提供參考,不一定能成為您想要的結果。以下是mysql 日期和時光格局轉換完成語句正文


這裡是一個應用日期函數的例子。上面的查詢選擇了一切記載,其date_col的值是在最初30天之內:

mysql> SELECT something FROM table
WHERE TO_DAYS(NOW()) - TO_DAYS(date_col) <= 30;

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()
 
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