MySQL の基本チュートリアル 9 — 日付と時刻の関数

黄舟
リリース: 2017-02-24 11:41:20
オリジナル
947 人が閲覧しました

以下の例では time 関数を使用しています。次のクエリは、過去 30 日以内の date_col 値を持つすべてのレコードを選択します。

mysql> SELECT something FROM tbl_name
-> WHERE DATE_SUB(CURDATE(),INTERVAL 30 DAY) <= date_col;
ログイン後にコピー


このクエリは、将来の日付を持つレコードも選択できることに注意してください。

日付値の関数は通常、時刻の日付値を受け入れ、時刻の部分を無視します。また、時間値の関数は通常、時間日付値を受け入れ、日付部分を無視します。

それぞれの現在の日付または時刻を返す関数は、各クエリ実行の開始時に 1 回評価されます。これは、単一のクエリ内で NOW() などの関数に複数回アクセスすると、 ) と呼ばれるすべてのサブルーチンの呼び出しが常に同じ結果になることを意味します。この原則は、CURDATE()、CURTIME()、UTC_DATE()、UTC_TIME()、UTC_TIMESTAMP()、および同じ意味を持つすべての関数にも適用されます。

CURRENT_TIMESTAMP()、CURRENT_TIME()、CURRENT_DATE()、および FROM_UNIXTIME() 関数は、接続の現在のタイムゾーンの値を返します。この値は、time_zone システム変数の値として使用できます。さらに、UNIX_TIMESTAMP() は、引数が現在のタイムゾーンの日付と時刻の値であると想定します。

次の関数の説明の戻り値の範囲は、完全な日付を要求します。 日付の値が「ゼロ」である場合、または「2001-11-00」などの不完全な日付である場合、部分的な日付値を抽出する関数は 0 を返すことがあります。 たとえば、DAYOFMONTH('2001-11-00') は 0 を返します。

  • ADDDATE(date,INTERVAL expr type) ADDDATE(expr,days)

2 番目のパラメーターの INTERVAL 形式によってアクティブ化された場合、ADDDATE() は DATE_ADD( )の同義語。関連関数 SUBDATE() は DATE_SUB() の同義語です。 INTERVAL パラメータの詳細については、DATE_ADD() の説明を参照してください。

mysql> SELECT DATE_ADD(&#39;1998-01-02&#39;, INTERVAL 31 DAY);
-> &#39;1998-02-02&#39;
mysql> SELECT ADDDATE(&#39;1998-01-02&#39;, INTERVAL 31 DAY);
-> &#39;1998-02-02&#39;
若 days 参数只是整数值,则 MySQL 5.1将其作为天数值添加至 expr。
mysql> SELECT ADDDATE(&#39;1998-01-02&#39;, 31);
-> &#39;1998-02-02&#39;
ログイン後にコピー
  • ADDTIME(expr,expr2)

ADDTIME()は、expr2exprに加算し、結果を返します。 expr は時刻または日時の式であり、expr2 は時間の式です。

mysql> SELECT ADDTIME(&#39;1997-12-31 23:59:59.999999&#39;,
->                &#39;1 1:1:1.000002&#39;);
-> &#39;1998-01-02 01:01:01.000001&#39;
mysql> SELECT ADDTIME(&#39;01:00:00.999999&#39;, &#39;02:00:00.999998&#39;);
-> &#39;03:00:01.999997&#39;
ログイン後にコピー
  • CONVERT_TZ(dt,from_tz,to_tz)

CONVERT_TZ() 時刻日付値dtfrom_tzタイムゾーンで指定されたタイムゾーンに変換しますto_tzによって与えられました、結果の値を返します。引数が無効な場合、この関数は NULL を返します。

from_tzからUTCへの変換プロセス中に、値がTIMESTAMP型のサポートされている範囲を超える場合、変換は行われません。

mysql> SELECT CONVERT_TZ(&#39;2004-01-01 12:00:00&#39;,&#39;GMT&#39;,&#39;MET&#39;);
-> &#39;2004-01-01 13:00:00&#39;
mysql> SELECT CONVERT_TZ(&#39;2004-01-01 12:00:00&#39;,&#39;+00:00&#39;,&#39;+10:00&#39;);
-> &#39;2004-01-01 22:00:00&#39;
ログイン後にコピー

: 「MET」や「ヨーロッパ/モスクワ」などの指定されたタイムゾーンを使用するには、まず正しいタイムゾーンテーブルを設定します。

  • CURDATE()

現在の日付を「YYYY-MM-DD」またはYYYYMMDDの形式で返します。具体的な形式は、関数が文字列コンテキストで使用されるか数値コンテキストで使用されるかによって異なります。

mysql> SELECT CURDATE();
-> &#39;1997-12-15&#39;
mysql> SELECT CURDATE() + 0;
-> 19971215
ログイン後にコピー

  • CURRENT_DATE()

CURRENT_DATEとCURRENT_DATE()は同義語です

  • CURTIME()

現在の時刻を「HH:MM:SS」またはHHに変更します。 MMSSは特定の形式は、関数が文字列コンテキストで使用されるか数値コンテキストで使用されるかによって異なります。

mysql> SELECT CURTIME();
-> &#39;23:50:26&#39;
mysql> SELECT CURTIME() + 0;
-> 235026
ログイン後にコピー

  • CURRENT_TIME、CURRENT_TIME()

CURRENT_TIMEとCURRENT_TIME()はCURTIME()の同義語です。

  • CURRENT_TIMESTAMP、CURRENT_TIMESTAMP()

CURRENT_TIMESTAMPおよびCURRENT_TIMESTAMP()はNOW()の同義語です。

  • DATE(

    expr)

日付または時刻の日付式

expr の日付部分を抽出します。

mysql> SELECT DATE(&#39;2003-12-31 01:02:03&#39;);
-> &#39;2003-12-31&#39;
ログイン後にコピー

  • DATEDIFF(

    expr,expr2)

DATEDIFF()は、開始時刻

exprと終了時刻expr2の間の日数を返します。 Exprexpr2 は、日付または日付と時刻の式です。これらの値の日付部分のみが計算に使用されます。

mysql> SELECT DATEDIFF(&#39;1997-12-31 23:59:59&#39;,&#39;1997-12-30&#39;);
-> 1
mysql> SELECT DATEDIFF(&#39;1997-11-30 23:59:59&#39;,&#39;1997-12-31&#39;);
-> -31
ログイン後にコピー

  • DATE_ADD(

    date,INTERVAL expr type) DATE_SUB(date,INTERVAL expr type)

日付操作。

date は、開始時刻を指定するために使用される DATETIME または DATE 値です。 expr は、開始日から加算または減算される時間間隔の値を指定する式です。 Expr は文字列です。負の間隔の場合は、「-」で始めることができます。 type は式がどのように解釈されるかを示すキーワードです。

キーワード INTERVA と

type 分類子は大文字と小文字を区別しません。

次の表は、type パラメータと expr パラメータの関係を示しています。

マイクロ秒マイクロ秒四半期年SECOND_ MICROSECONDMINUTE_MICROSECONDMINUTE_SECONDHOUR_MICROSECONDHOUR_SECONDHOUR_MINUTEDAY_MICROSECONDDAY_SECONDDAY_MINUTEDAY_HOURYEAR_MONTH

MySQL 允许任何expr 格式中的标点分隔符。表中所显示的是建议的 分隔符。若 date 参数是一个 DATE 值,而你的计算只会包括 YEAR、MONTH和DAY部分(即, 没有时间部分), 其结果是一个DATE 值。否则,结果将是一个 DATETIME值。

若位于另一端的表达式是一个日期或日期时间值 , 则INTERVAL expr type只允许在 + 操作符的两端。对于 –操作符, INTERVAL expr type 只允许在其右端,原因是从一个时间间隔中提取一个日期或日期时间值是毫无意义的。 (见下面的例子)。

mysql> SELECT &#39;1997-12-31 23:59:59&#39; + INTERVAL 1 SECOND;
-> &#39;1998-01-01 00:00:00&#39;
mysql> SELECT INTERVAL 1 DAY + &#39;1997-12-31&#39;;
-> &#39;1998-01-01&#39;
mysql> SELECT &#39;1998-01-01&#39; - INTERVAL 1 SECOND;
-> &#39;1997-12-31 23:59:59&#39;
mysql> SELECT DATE_ADD(&#39;1997-12-31 23:59:59&#39;,
->                 INTERVAL 1 SECOND);
-> &#39;1998-01-01 00:00:00&#39;
mysql> SELECT DATE_ADD(&#39;1997-12-31 23:59:59&#39;,
->                 INTERVAL 1 DAY);
-> &#39;1998-01-01 23:59:59&#39;
mysql> SELECT DATE_ADD(&#39;1997-12-31 23:59:59&#39;,
->                 INTERVAL &#39;1:1&#39; MINUTE_SECOND);
-> &#39;1998-01-01 00:01:00&#39;
mysql> SELECT DATE_SUB(&#39;1998-01-01 00:00:00&#39;,
->                 INTERVAL &#39;1 1:1:1&#39; DAY_SECOND);
-> &#39;1997-12-30 22:58:59&#39;
mysql> SELECT DATE_ADD(&#39;1998-01-01 00:00:00&#39;,
->                 INTERVAL &#39;-1 10&#39; DAY_HOUR);
-> &#39;1997-12-30 14:00:00&#39;
mysql> SELECT DATE_SUB(&#39;1998-01-02&#39;, INTERVAL 31 DAY);
-> &#39;1997-12-02&#39;
mysql> SELECT DATE_ADD(&#39;1992-12-31 23:59:59.000002&#39;,
->            INTERVAL &#39;1.999999&#39; SECOND_MICROSECOND);
-> &#39;1993-01-01 00:00:01.000001&#39;
ログイン後にコピー

若你指定了一个过于短的时间间隔值 (不包括type 关键词所预期的所有时间间隔部分), MySQL 假定你已经省去了时间间隔值的最左部分。 例如,你指定了一种类型的DAY_SECOND, expr 的值预期应当具有天、 小时、分钟和秒部分。若你指定了一个类似 '1:10'的值, MySQL 假定天和小时部分不存在,那么这个值代表分和秒。换言之, '1:10' DAY_SECOND 被解释为相当于 '1:10' MINUTE_SECOND。这相当于 MySQL将TIME 值解释为所耗费的时间而不是日时的解释方式。

假如你对一个日期值添加或减去一些含有时间部分的内容,则结果自动转化为一个日期时间值:

mysql> SELECT DATE_ADD(&#39;1999-01-01&#39;, INTERVAL 1 DAY);
-> &#39;1999-01-02&#39;
mysql> SELECT DATE_ADD(&#39;1999-01-01&#39;, INTERVAL 1 HOUR);
-> &#39;1999-01-01 01:00:00&#39;
ログイン後にコピー

假如你使用了格式严重错误的日期,则结果为 NULL。假如你添加了 MONTH、YEAR_MONTH或YEAR ,而结果日期中有一天的日期大于添加的月份的日期最大限度,则这个日期自动被调整为添加月份的最大日期:

mysql> SELECT DATE_ADD(&#39;1998-01-30&#39;, INTERVAL 1 MONTH);
-> &#39;1998-02-28&#39;
ログイン後にコピー
  • DATE_FORMAT(date,format)

根据format 字符串安排date 值的格式。

以下说明符可用在 format 字符串中:

週間ヶ月
四半期
'SECONDS.MICROSECONDS'
'MINUTES .MICROSECONDS'
'MINUTES:SECONDS'
'HOURS.MICROSECONDS'
'時間:分:秒'
'時間:MINUTES'
'DAYS.MICROSECONDS'
'DAYS 時間:分:秒'
'日時間:分'
「日時間」
「年-月」
说明符说明
%a工作日的缩写名称 (Sun..Sat)
%b月份的缩写名称 (Jan..Dec)
%c月份,数字形式(0..12)
%D带有英语后缀的该月日期 (0th, 1st, 2nd, 3rd, ...)
%d该月日期, 数字形式 (00..31)
%e该月日期, 数字形式(0..31)
%f微秒 (000000..999999)
%H小时(00..23)
%h小时(01..12)
%I小时 (01..12)
%i分钟,数字形式 (00..59)
%j一年中的天数 (001..366)
%k小时 (0..23)
%l小时 (1..12)
%M月份名称 (January..December)
%m月份, 数字形式 (00..12)
%p上午(AM)或下午( PM)
%r时间 , 12小时制 (小时hh:分钟mm:秒数ss 后加 AM或PM)
%S秒 (00..59)
%s秒 (00..59)
%T时间 , 24小时制 (小时hh:分钟mm:秒数ss)
%U周 (00..53), 其中周日为每周的第一天
%u周 (00..53), 其中周一为每周的第一天
%V周 (01..53), 其中周日为每周的第一天 ; 和 %X同时使用
%v周 (01..53), 其中周一为每周的第一天 ; 和 %x同时使用
%W工作日名称 (周日..周六)
%w一周中的每日 (0=周日..6=周六)
%X该周的年份,其中周日为每周的第一天, 数字形式,4位数;和%V同时使用
%x该周的年份,其中周一为每周的第一天, 数字形式,4位数;和%v同时使用
%Y年份, 数字形式,4位数
%y年份, 数字形式 (2位数)
%%‘%’文字字符

所有其它字符都被复制到结果中,无需作出解释。

注意, ‘%’字符要求在格式指定符之前。

月份和日期说明符的范围从零开始,原因是 MySQL允许存储诸如 '2004-00-00'的不完全日期.

mysql> SELECT DATE_FORMAT(&#39;1997-10-04 22:23:00&#39;, &#39;%W %M %Y&#39;);        -> &#39;Saturday October 1997&#39;
mysql> SELECT DATE_FORMAT(&#39;1997-10-04 22:23:00&#39;, &#39;%H:%i:%s&#39;);        -> &#39;22:23:00&#39;
mysql> SELECT DATE_FORMAT(&#39;1997-10-04 22:23:00&#39;,                          &#39;%D %y %a %d %m %b %j&#39;);
        -> &#39;4th 97 Sat 04 10 Oct 277&#39;
mysql> SELECT DATE_FORMAT(&#39;1997-10-04 22:23:00&#39;,                          &#39;%H %k %I %r %T %S %w&#39;);
        -> &#39;22 22 10 10:23:00 PM 22:23:00 00 6&#39;
mysql> SELECT DATE_FORMAT(&#39;1999-01-01&#39;, &#39;%X %V&#39;);        -> &#39;1998 52&#39;
ログイン後にコピー
  • DAY(date)

DAY() 和DAYOFMONTH()的意义相同。

  • DAYNAME(date)

返回date 对应的工作日名称。

mysql> SELECT DAYNAME(&#39;1998-02-05&#39;);
-> &#39;周四&#39;
ログイン後にコピー
  • DAYOFMONTH(date)

返回date 对应的该月日期,范围是从 1到31。

mysql> SELECT DAYOFMONTH(&#39;1998-02-03&#39;);
-> 3
ログイン後にコピー
  • DAYOFWEEK(date)

返回date (1 = 周日, 2 = 周一, ..., 7 = 周六)对应的工作日索引。这些索引值符合 ODBC标准。

mysql> SELECT DAYOFWEEK(&#39;1998-02-03&#39;);
-> 3
ログイン後にコピー
  • DAYOFYEAR(date)

返回date 对应的一年中的天数,范围是从 1到366。

mysql> SELECT DAYOFYEAR(&#39;1998-02-03&#39;);
-> 34
ログイン後にコピー
  • EXTRACT(type FROM date)

EXTRACT()函数所使用的时间间隔类型说明符同 DATE_ADD()或DATE_SUB()的相同,但它从日期中提取其部分,而不是执行日期运算。

mysql> SELECT EXTRACT(YEAR FROM &#39;1999-07-02&#39;);
-> 1999
mysql> SELECT EXTRACT(YEAR_MONTH FROM &#39;1999-07-02 01:02:03&#39;);
-> 199907
mysql> SELECT EXTRACT(DAY_MINUTE FROM &#39;1999-07-02 01:02:03&#39;);
-> 20102
mysql> SELECT EXTRACT(MICROSECOND
->                FROM &#39;2003-01-02 10:30:00.00123&#39;);
-> 123
ログイン後にコピー
  • FROM_DAYS(N)

给定一个天数 N, 返回一个DATE值。

mysql> SELECT FROM_DAYS(729669);

-> &#39;1997-10-07&#39;

使用 FROM_DAYS()处理古老日期时,务必谨慎。他不用于处理阳历出现前的日期(1582)。

  • FROM_UNIXTIME(unix_timestamp) , FROM_UNIXTIME(unix_timestamp,format)

返回'YYYY-MM-DD HH:MM:SS'或YYYYMMDDHHMMSS 格式值的unix_timestamp参数表示,具体格式取决于该函数是否用在字符串中或是数字语境中。

format 已经给出,则结果的格式是根据format 字符串而定。 format 可以包含同DATE_FORMAT() 函数输入项列表中相同的说明符。

mysql> SELECT FROM_UNIXTIME(875996580);
-> &#39;1997-10-04 22:23:00&#39;
mysql> SELECT FROM_UNIXTIME(875996580) + 0;
-> 19971004222300
mysql> SELECT FROM_UNIXTIME(UNIX_TIMESTAMP(),
->                      &#39;%Y %D %M %h:%i:%s %x&#39;);
-> &#39;2003 6th August 06:22:58 2003&#39;
ログイン後にコピー
  • GET_FORMAT(DATE|TIME|DATETIME, 'EUR'|'USA'|'JIS'|'ISO'|'INTERNAL')

返回一个格式字符串。这个函数在同DATE_FORMAT() 及STR_TO_DATE()函数结合时很有用。

第一个参数的3个可能值和第二个参数的5个可能值产生 15 个可能格式字符串 (对于使用的说明符,请参见DATE_FORMAT()函数说明表 )。

函数调用结果
GET_FORMAT(DATE,'USA')'%m.%d.%Y'
GET_FORMAT(DATE,'JIS')'%Y-%m-%d'
GET_FORMAT(DATE,'ISO')'%Y-%m-%d'
GET_FORMAT(DATE,'EUR')'%d.%m.%Y'
GET_FORMAT(DATE,'INTERNAL')'%Y%m%d'
GET_FORMAT(DATETIME,'USA')'%Y-%m-%d-%H.%i.%s'
GET_FORMAT(DATETIME,'JIS')'%Y-%m-%d %H:%i:%s'
GET_FORMAT(DATETIME,'ISO')'%Y-%m-%d %H:%i:%s'
GET_FORMAT(DATETIME,'EUR')'%Y-%m-%d-%H.%i.%s'
GET_FORMAT(DATETIME,'INTERNAL')'%Y%m%d%H%i%s'
GET_FORMAT(TIME,'USA')'%h:%i:%s %p'
GET_FORMAT(TIME,'JIS')'%H:%i:%s'
GET_FORMAT(TIME,'ISO')'%H:%i:%s'
GET_FORMAT(TIME,'EUR')'%H.%i.%S'
GET_FORMAT(TIME,'INTERNAL')'%H%i%s'

ISO 格式为ISO 9075, 而非ISO 8601.

也可以使用TIMESTAMP, 这时GET_FORMAT()的返回值和DATETIME相同。

mysql> SELECT DATE_FORMAT(&#39;2003-10-03&#39;,GET_FORMAT(DATE,&#39;EUR&#39;));
-> &#39;03.10.2003&#39;
mysql> SELECT STR_TO_DATE(&#39;10.31.2003&#39;,GET_FORMAT(DATE,&#39;USA&#39;));
-> &#39;2003-10-31&#39;
ログイン後にコピー
  • HOUR(time)

返回time 对应的小时数。对于日时值的返回值范围是从 0 到 23 。

mysql> SELECT HOUR('10:05:03');

-> 10

然而, TIME 值的范围实际上非常大, 所以HOUR可以返回大于23的值。

mysql> SELECT HOUR('272:59:59');

-> 272

  • LAST_DAY(date)

获取一个日期或日期时间值,返回该月最后一天对应的值。若参数无效,则返回NULL。

mysql> SELECT LAST_DAY(&#39;2003-02-05&#39;);
-> &#39;2003-02-28&#39;
mysql> SELECT LAST_DAY(&#39;2004-02-05&#39;);
-> &#39;2004-02-29&#39;
mysql> SELECT LAST_DAY(&#39;2004-01-01 01:01:01&#39;);
-> &#39;2004-01-31&#39;
mysql> SELECT LAST_DAY(&#39;2003-03-32&#39;);
-> NULL
ログイン後にコピー
  • LOCALTIME, LOCALTIME()

LOCALTIME 及 LOCALTIME()和NOW()具有相同意义。

  • LOCALTIMESTAMP, LOCALTIMESTAMP()

LOCALTIMESTAMP和LOCALTIMESTAMP()和NOW()具有相同意义。

  • MAKEDATE(year,dayofyear)

给出年份值和一年中的天数值,返回一个日期。dayofyear 必须大于 0 ,否则结果为 NULL。

mysql> SELECT MAKEDATE(2001,31), MAKEDATE(2001,32);
-> &#39;2001-01-31&#39;, &#39;2001-02-01&#39;
mysql> SELECT MAKEDATE(2001,365), MAKEDATE(2004,365);
-> &#39;2001-12-31&#39;, &#39;2004-12-30&#39;
mysql> SELECT MAKEDATE(2001,0);
-> NULL
ログイン後にコピー
  • MAKETIME(hour,minute,second)

返回由hourminutesecond 参数计算得出的时间值。

mysql> SELECT MAKETIME(12,15,30);
-> &#39;12:15:30&#39;
ログイン後にコピー
  • MICROSECOND(expr)

从时间或日期时间表达式expr返回微秒值,其数字范围从 0到 999999。

mysql> SELECT MICROSECOND(&#39;12:00:00.123456&#39;);
-> 123456
mysql> SELECT MICROSECOND(&#39;1997-12-31 23:59:59.000010&#39;);
-> 10
ログイン後にコピー
  • MINUTE(time)

返回 time 对应的分钟数,范围是从 0 到 59。

mysql> SELECT MINUTE(&#39;98-02-03 10:05:03&#39;);
-> 5
ログイン後にコピー
  • MONTH(date)

返回date 对应的月份,范围时从 1 到 12。

mysql> SELECT MONTH(&#39;1998-02-03&#39;);
-> 2
ログイン後にコピー
  • MONTHNAME(date)

返回date 对应月份的全名。

mysql> SELECT MONTHNAME(&#39;1998-02-05&#39;);
-> &#39;February &#39;
ログイン後にコピー
  • NOW()

返回当前日期和时间值,其格式为 'YYYY-MM-DD HH:MM:SS' 或YYYYMMDDHHMMSS , 具体格式取决于该函数是否用在字符串中或数字语境中。

mysql> SELECT NOW();
-> &#39;1997-12-15 23:50:26&#39;
mysql> SELECT NOW() + 0;
-> 19971215235026
ログイン後にコピー

在一个存储程序或触发器内, NOW() 返回一个常数时间,该常数指示了该程序或触发语句开始执行的时间。这同SYSDATE()的运行有所不同。

  • PERIOD_ADD(P,N)

添加 N 个月至周期P (格式为YYMM 或YYYYMM),返回值的格式为 YYYYMM。注意周期参数 P 不是日期值。

mysql> SELECT PERIOD_ADD(9801,2);
-> 199803
ログイン後にコピー
  • PERIOD_DIFF(P1,P2)

返回周期P1P2 之间的月份数。P1P2 的格式应该为YYMM或YYYYMM。注意周期参数 P1P2 不是日期值。

mysql> SELECT PERIOD_DIFF(9802,199703);
-> 11
ログイン後にコピー
  • QUARTER(date)

返回date 对应的一年中的季度值,范围是从 1到 4。

mysql> SELECT QUARTER(&#39;98-04-01&#39;);
-> 2
ログイン後にコピー
  • SECOND(time)

返回time 对应的秒数, 范围是从 0到59。

mysql> SELECT SECOND(&#39;10:05:03&#39;);
-> 3
ログイン後にコピー
  • SEC_TO_TIME(seconds)

返回被转化为小时、 分钟和秒数的seconds参数值, 其格式为 'HH:MM:SS' 或HHMMSS,具体格式根据该函数是否用在字符串或数字语境中而定。

mysql> SELECT SEC_TO_TIME(2378);
-> &#39;00:39:38&#39;
mysql> SELECT SEC_TO_TIME(2378) + 0;
-> 3938
ログイン後にコピー
  • STR_TO_DATE(str,format)

这是DATE_FORMAT() 函数的倒转。它获取一个字符串 str 和一个格式字符串format。若格式字符串包含日期和时间部分,则 STR_TO_DATE()返回一个 DATETIME 值, 若该字符串只包含日期部分或时间部分,则返回一个 DATE 或TIME值。

str所包含的日期、时间或日期时间值应该在format指示的格式中被给定。对于可用在format中的说明符,请参见DATE_FORMAT() 函数说明表。 所有其它的字符被逐字获取,因此不会被解释。若 str 包含一个非法日期、时间或日期时间值,则 STR_TO_DATE()返回NULL。同时,一个非法值会引起警告。

其意义是,例如, 只要具体日期部分的范围时从 1到 31之间,则允许一个日期中的具体日期部分大于一个月中天数值。并且,允许“零”日期或带有0值部分的日期。

mysql> SELECT STR_TO_DATE(&#39;00/00/0000&#39;, &#39;%m/%d/%Y&#39;);
-> &#39;0000-00-00&#39;
mysql> SELECT STR_TO_DATE(&#39;04/31/2004&#39;, &#39;%m/%d/%Y&#39;);
-> &#39;2004-04-31&#39;
ログイン後にコピー
  • SUBDATE(date,INTERVAL expr type) SUBDATE(expr,days)

当被第二个参数的 INTERVAL型式调用时, SUBDATE()和DATE_SUB()的意义相同。对于有关INTERVAL参数的信息, 见有关 DATE_ADD()的讨论。

mysql> SELECT DATE_SUB(&#39;1998-01-02&#39;, INTERVAL 31 DAY);
-> &#39;1997-12-02&#39;
mysql> SELECT SUBDATE(&#39;1998-01-02&#39;, INTERVAL 31 DAY);
-> &#39;1997-12-02&#39;
ログイン後にコピー

第二个形式允许对days使用整数值。在这些情况下,它被算作由日期或日期时间表达式 expr中提取的天数。

mysql> SELECT SUBDATE(&#39;1998-01-02 12:00:00&#39;, 31);
-> &#39;1997-12-02 12:00:00&#39;
ログイン後にコピー

注意不能使用格式 "%X%V" 来将一个 year-week 字符串转化为一个日期,原因是当一个星期跨越一个月份界限时,一个年和星期的组合不能标示一个唯一的年和月份。若要将year-week转化为一个日期,则也应指定具体工作日:

mysql> select str_to_date(&#39;200442 Monday&#39;, &#39;%X%V %W&#39;);
-> 2004-10-18
ログイン後にコピー
  • SUBTIME(expr,expr2)

SUBTIME()从expr 中提取expr2 ,然后返回结果。expr 是一个时间或日期时间表达式,而xpr2 是一个时间表达式。

mysql> SELECT SUBTIME(&#39;1997-12-31 23:59:59.999999&#39;,&#39;1 1:1:1.000002&#39;);
-> &#39;1997-12-30 22:58:58.999997&#39;
mysql> SELECT SUBTIME(&#39;01:00:00.999999&#39;, &#39;02:00:00.999998&#39;);
-> &#39;-00:59:59.999999&#39;
ログイン後にコピー
  • SYSDATE()

返回当前日期和时间值,格式为'YYYY-MM-DD HH:MM:SS' 或YYYYMMDDHHMMSS, 具体格式根据函数是否用在字符串或数字语境而定。

在一个存储程序或触发器中, SYSDATE()返回其执行的时间, 而非存储成都或触发语句开始执行的时间。这个NOW()的运作有所不同。

  • TIME(expr)

提取一个时间或日期时间表达式的时间部分,并将其以字符串形式返回。

mysql> SELECT TIME(&#39;2003-12-31 01:02:03&#39;);
-> &#39;01:02:03&#39;
mysql> SELECT TIME(&#39;2003-12-31 01:02:03.000123&#39;);
-> &#39;01:02:03.000123&#39;
ログイン後にコピー
  • TIMEDIFF(expr,expr2)

TIMEDIFF() 返回起始时间 expr 和结束时间expr2 之间的时间。 exprexpr2 为时间或 date-and-time 表达式,两个的类型必须一样。

mysql> SELECT TIMEDIFF(&#39;2000:01:01 00:00:00&#39;,
->                 &#39;2000:01:01 00:00:00.000001&#39;);
-> &#39;-00:00:00.000001&#39;
mysql> SELECT TIMEDIFF(&#39;1997-12-31 23:59:59.000001&#39;,
->                 &#39;1997-12-30 01:01:01.000002&#39;);
-> &#39;46:58:57.999999&#39;
ログイン後にコピー
  • TIMESTAMP(expr) , TIMESTAMP(expr,expr2)

对于一个单参数,该函数将日期或日期时间表达式 expr 作为日期时间值返回.对于两个参数, 它将时间表达式 expr2 添加到日期或日期时间表达式 expr 中,将theresult作为日期时间值返回。

mysql> SELECT TIMESTAMP(&#39;2003-12-31&#39;);
-> &#39;2003-12-31 00:00:00&#39;
mysql> SELECT TIMESTAMP(&#39;2003-12-31 12:00:00&#39;,&#39;12:00:00&#39;);
-> &#39;2004-01-01 00:00:00&#39;
ログイン後にコピー
  • TIMESTAMPADD(interval,int_expr,datetime_expr)

将整型表达式int_expr 添加到日期或日期时间表达式 datetime_expr中。 int_expr 的单位被时间间隔参数给定,该参数必须是以下值的其中一个: FRAC_SECOND、SECOND、 MINUTE、 HOUR、 DAY、 WEEK、 MONTH、 QUARTER或 YEAR。

可使用所显示的关键词指定Interval值,或使用SQL_TSI_前缀。例如, DAY或SQL_TSI_DAY 都是正确的。

mysql> SELECT TIMESTAMPADD(MINUTE,1,&#39;2003-01-02&#39;);
-> &#39;2003-01-02 00:01:00&#39;
mysql> SELECT TIMESTAMPADD(WEEK,1,&#39;2003-01-02&#39;);
-> &#39;2003-01-09&#39;
ログイン後にコピー
  • TIMESTAMPDIFF(interval,datetime_expr1,datetime_expr2)

返回日期或日期时间表达式datetime_expr1datetime_expr2the 之间的整数差。其结果的单位由interval 参数给出。interval 的法定值同TIMESTAMPADD()函数说明中所列出的相同。

mysql> SELECT TIMESTAMPDIFF(MONTH,&#39;2003-02-01&#39;,&#39;2003-05-01&#39;);
-> 3
mysql> SELECT TIMESTAMPDIFF(YEAR,&#39;2002-05-01&#39;,&#39;2001-01-01&#39;);
-> -1
ログイン後にコピー
  • TIME_FORMAT(time,format)

其使用和 DATE_FORMAT()函数相同, 然而format 字符串可能仅会包含处理小时、分钟和秒的格式说明符。其它说明符产生一个NULL值或0。

time value包含一个大于23的小时部分,则 %H 和 %k 小时格式说明符会产生一个大于0..23的通常范围的值。另一个小时格式说明符产生小时值模数12。

mysql> SELECT TIME_FORMAT(&#39;100:00:00&#39;, &#39;%H %k %h %I %l&#39;);
-> &#39;100 100 04 04 4&#39;
ログイン後にコピー
  • TIME_TO_SEC(time)

返回已转化为秒的time参数。

mysql> SELECT TIME_TO_SEC(&#39;22:23:00&#39;);
-> 80580
mysql> SELECT TIME_TO_SEC(&#39;00:39:38&#39;);
-> 2378
ログイン後にコピー
  • TO_DAYS(date)

给定一个日期date, 返回一个天数 (从年份0开始的天数 )。

mysql> SELECT TO_DAYS(950501);
-> 728779
mysql> SELECT TO_DAYS(&#39;1997-10-07&#39;);
-> 729669
ログイン後にコピー

TO_DAYS() 不用于阳历出现(1582)前的值,原因是当日历改变时,遗失的日期不会被考虑在内。

请记住, MySQL使用“日期和时间类型”中的规则将日期中的二位数年份值转化为四位。例如, '1997-10-07'和'97-10-07' 被视为同样的日期:

mysql> SELECT TO_DAYS(&#39;1997-10-07&#39;), TO_DAYS(&#39;97-10-07&#39;);
-> 729669, 729669
ログイン後にコピー

对于1582 年之前的日期(或许在其它地区为下一年 ), 该函数的结果实不可靠的。

  • UNIX_TIMESTAMP(), UNIX_TIMESTAMP(date)

若无参数调用,则返回一个Unix timestamp ('1970-01-01 00:00:00' GMT 之后的秒数) 作为无符号整数。若用date 来调用UNIX_TIMESTAMP(),它会将参数值以'1970-01-01 00:00:00' GMT后的秒数的形式返回。date 可以是一个DATE 字符串、一个 DATETIME字符串、一个 TIMESTAMP或一个当地时间的YYMMDD 或YYYMMDD格式的数字。

mysql> SELECT UNIX_TIMESTAMP();
-> 882226357
mysql> SELECT UNIX_TIMESTAMP(&#39;1997-10-04 22:23:00&#39;);
-> 875996580
ログイン後にコピー

当 UNIX_TIMESTAMP被用在 TIMESTAMP列时, 函数直接返回内部时戳值, 而不进行任何隐含的 “string-to-Unix-timestamp”转化。假如你向UNIX_TIMESTAMP()传递一个溢出日期,它会返回 0,但请注意只有基本范围检查会被履行(年份从1970 到 2037, 月份从01到12,日期从 01 到31)。

假如你想要减去 UNIX_TIMESTAMP() 列, 你或许希望删去带符号整数的结果。

  • UTC_DATE, UTC_DATE()

返回当前 UTC日期值,其格式为 'YYYY-MM-DD' 或 YYYYMMDD,具体格式取决于函数是否用在字符串或数字语境中。

mysql> SELECT UTC_DATE(), UTC_DATE() + 0;
-> &#39;2003-08-14&#39;, 20030814
ログイン後にコピー
  • UTC_TIME, UTC_TIME()

返回当前 UTC 值,其格式为 'HH:MM:SS' 或HHMMSS,具体格式根据该函数是否用在字符串或数字语境而定。

mysql> SELECT UTC_TIME(), UTC_TIME() + 0;
-> &#39;18:07:53&#39;, 180753
ログイン後にコピー
  • UTC_TIMESTAMP, UTC_TIMESTAMP()

返回当前UTC日期及时间值,格式为 'YYYY-MM-DD HH:MM:SS' 或YYYYMMDDHHMMSS,具体格式根据该函数是否用在字符串或数字语境而定。

mysql> SELECT UTC_TIMESTAMP(), UTC_TIMESTAMP() + 0;
-> &#39;2003-08-14 18:08:04&#39;, 20030814180804
ログイン後にコピー
  • WEEK(date[,mode])

该函数返回date 对应的星期数。WEEK() 的双参数形式允许你指定该星期是否起始于周日或周一, 以及返回值的范围是否为从0 到53 或从1 到53。若 mode参数被省略,则使用default_week_format系统自变量的值。

以下表说明了mode 参数的工作过程:d


第一天

Mode工作日范围Week 1 为第一周 ...
0周日0-53本年度中有一个周日
1周一0-53本年度中有3天以上
2周日1-53本年度中有一个周日
3周一1-53本年度中有3天以上
4周日0-53本年度中有3天以上
5周一0-53本年度中有一个周一
6周日1-53本年度中有3天以上
7周一1-53本年度中有一个周一
mysql> SELECT WEEK(&#39;1998-02-20&#39;);
-> 7
mysql> SELECT WEEK(&#39;1998-02-20&#39;,0);
-> 7
mysql> SELECT WEEK(&#39;1998-02-20&#39;,1);
-> 8
mysql> SELECT WEEK(&#39;1998-12-31&#39;,1);
-> 53
ログイン後にコピー

注意,假如有一个日期位于前一年的最后一周, 若你不使用2、3、6或7作为mode 参数选择,则MySQL返回 0:

mysql> SELECT YEAR(&#39;2000-01-01&#39;), WEEK(&#39;2000-01-01&#39;,0);
-> 2000, 0
ログイン後にコピー

有人或许会提出意见,认为 MySQL 对于WEEK() 函数应该返回 52 ,原因是给定的日期实际上发生在1999年的第52周。我们决定返回0作为代替的原因是我们希望该函数能返回“给定年份的星期数”。这使得WEEK() 函数在同其它从日期中抽取日期部分的函数结合时的使用更加可靠。

假如你更希望所计算的关于年份的结果包括给定日期所在周的第一天,则应使用 0、2、5或 7 作为mode参数选择。

mysql> SELECT WEEK(&#39;2000-01-01&#39;,2);
-> 52
作为选择,可使用 YEARWEEK()函数:
mysql> SELECT YEARWEEK(&#39;2000-01-01&#39;);
-> 199952
mysql> SELECT MID(YEARWEEK(&#39;2000-01-01&#39;),5,2);
-> &#39;52&#39;
ログイン後にコピー
  • WEEKDAY(date)

返回date (0 = 周一, 1 = 周二, ... 6 = 周日)对应的工作日索引 weekday index for

mysql> SELECT WEEKDAY(&#39;1998-02-03 22:23:00&#39;);
-> 1
mysql> SELECT WEEKDAY(&#39;1997-11-05&#39;);
-> 2
ログイン後にコピー
  • WEEKOFYEAR(date)

将该日期的阳历周以数字形式返回,范围是从1到53。它是一个兼容度函数,相当于WEEK(date,3)。

mysql> SELECT WEEKOFYEAR(&#39;1998-02-20&#39;);
-> 8
ログイン後にコピー
  • YEAR(date)

返回date 对应的年份,范围是从1000到9999。

mysql> SELECT YEAR(&#39;98-02-03&#39;);
-> 1998
ログイン後にコピー
  • YEARWEEK(date), YEARWEEK(date,start)

返回一个日期对应的年或周。start参数的工作同 start参数对 WEEK()的工作相同。结果中的年份可以和该年的第一周和最后一周对应的日期参数有所不同。

mysql> SELECT YEARWEEK('1987-01-01');

-> 198653

注意,周数和WEEK()函数队可选参数0或 1可能会返回的(0) w有所不同,原因是此时 WEEK() 返回给定年份的语境中的周。


  • -> &#39;1997-10-07&#39;
    ログイン後にコピー

     以上就是MySQL基础教程9 —— 函数之日期和时间函数的内容,更多相关内容请关注PHP中文网(www.php.cn)!


関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!