ステートメント
DATE_SUB(date,INTERVAL expr unit)
説明
日付時刻 date から expr を引いた値を返します。
dateは日付時刻の基準であり、DATEタイプ、TIMEタイプ、またはDATETIMEタイプを指定できます。exprは時間間隔を表し、負の値を指定できます。unitは時間間隔の単位を表します。
以下はすべての時間間隔単位のリストです:
| 単位 | タイプ | 意味 | フォーマット |
|---|---|---|---|
MICROSECOND |
独立 | マイクロ秒 | MICROSECONDS |
SECOND |
独立 | 秒 | SECONDS |
MINUTE |
独立 | 分 | MINUTES |
HOUR |
独立 | 時 | HOURS |
DAY |
独立 | 日 | DAYS |
WEEK |
独立 | 週 | WEEKS |
MONTH |
独立 | 月 | MONTHS |
QUARTER |
独立 | 四半期 | QUARTERS |
YEAR |
独立 | 年 | YEARS |
SECOND_MICROSECOND |
組み合わせ | 秒からマイクロ秒 | 'SECONDS.MICROSECONDS' |
MINUTE_MICROSECOND |
組み合わせ | 分からマイクロ秒 | 'MINUTES:SECONDS.MICROSECONDS' |
MINUTE_SECOND |
組み合わせ | 分から秒 | 'MINUTES:SECONDS' |
HOUR_MICROSECOND |
組み合わせ | 時からマイクロ秒 | 'HOURS:MINUTES:SECONDS.MICROSECONDS' |
HOUR_SECOND |
組み合わせ | 時から秒 | 'HOURS:MINUTES:SECONDS' |
HOUR_MINUTE |
組み合わせ | 時から分 | 'HOURS:MINUTES' |
DAY_SECOND |
組み合わせ | 日から秒 | 'DAYS HOURS:MINUTES:SECONDS' |
DAY_MINUTE |
組み合わせ | 日から分 | 'DDAYSD HOURS:MINUTES' |
DAY_HOUR |
組み合わせ | 日から時 | 'DAYS HOURS' |
YEAR_MONTH |
組み合わせ | 年から月 | 'YEARS-MONTHS' |
例
obclient> SELECT
DATE_SUB(NOW(), INTERVAL 5 DAY),
DATE_SUB('2014-01-10', INTERVAL 5 MICROSECOND),
DATE_SUB('2014-01-10', INTERVAL 5 SECOND),
DATE_SUB('2014-01-10', INTERVAL 5 MINUTE),
DATE_SUB('2014-01-10', INTERVAL 5 HOUR),
DATE_SUB('2014-01-10', INTERVAL 5 DAY),
DATE_SUB('2014-01-10', INTERVAL 5 WEEK),
DATE_SUB('2014-01-10', INTERVAL 5 MONTH),
DATE_SUB('2014-01-10', INTERVAL 5 QUARTER),
DATE_SUB('2014-01-10', INTERVAL 5 YEAR),
DATE_SUB('2014-01-10', INTERVAL '5.000005' SECOND_MICROSECOND),
DATE_SUB('2014-01-10', INTERVAL '05:05.000005' MINUTE_MICROSECOND),
DATE_SUB('2014-01-10', INTERVAL '05:05' MINUTE_SECOND),
DATE_SUB('2014-01-10', INTERVAL '05:05:05.000005' HOUR_MICROSECOND),
DATE_SUB('2014-01-10', INTERVAL '05:05:05' HOUR_SECOND),
DATE_SUB('2014-01-10', INTERVAL '05:05' HOUR_MINUTE),
DATE_SUB('2014-01-10', INTERVAL '01 05:05:05.000005' DAY_MICROSECOND),
DATE_SUB('2014-01-10', INTERVAL '01 05:05:05' DAY_SECOND),
DATE_SUB('2014-01-10', INTERVAL '01 05:05' DAY_MINUTE),
DATE_SUB('2014-01-10', INTERVAL '01 05' DAY_HOUR),
DATE_SUB('2014-01-10', INTERVAL '1-01' YEAR_MONTH)
\G
*************************** 1. row ***************************
DATE_SUB(NOW(), INTERVAL 5 DAY): 2021-08-18 14:56:32
DATE_SUB('2014-01-10', INTERVAL 5 MICROSECOND): 2014-01-09 23:59:59.999995
DATE_SUB('2014-01-10', INTERVAL 5 SECOND): 2014-01-09 23:59:55
DATE_SUB('2014-01-10', INTERVAL 5 MINUTE): 2014-01-09 23:55:00
DATE_SUB('2014-01-10', INTERVAL 5 HOUR): 2014-01-09 19:00:00
DATE_SUB('2014-01-10', INTERVAL 5 DAY): 2014-01-05
DATE_SUB('2014-01-10', INTERVAL 5 WEEK): 2013-12-06
DATE_SUB('2014-01-10', INTERVAL 5 MONTH): 2013-08-10
DATE_SUB('2014-01-10', INTERVAL 5 QUARTER): 2012-10-10
DATE_SUB('2014-01-10', INTERVAL 5 YEAR): 2009-01-10
DATE_SUB('2014-01-10', INTERVAL '5.000005' SECOND_MICROSECOND): 2014-01-09 23:59:54.999995
DATE_SUB('2014-01-10', INTERVAL '05:05.000005' MINUTE_MICROSECOND): 2014-01-09 23:54:54.999995
DATE_SUB('2014-01-10', INTERVAL '05:05' MINUTE_SECOND): 2014-01-09 23:54:55
DATE_SUB('2014-01-10', INTERVAL '05:05:05.000005' HOUR_MICROSECOND): 2014-01-09 18:54:54.999995
DATE_SUB('2014-01-10', INTERVAL '05:05:05' HOUR_SECOND): 2014-01-09 18:54:55
DATE_SUB('2014-01-10', INTERVAL '05:05' HOUR_MINUTE): 2014-01-09 18:55:00
DATE_SUB('2014-01-10', INTERVAL '01 05:05:05.000005' DAY_MICROSECOND): 2014-01-08 18:54:54.999995
DATE_SUB('2014-01-10', INTERVAL '01 05:05:05' DAY_SECOND): 2014-01-08 18:54:55
DATE_SUB('2014-01-10', INTERVAL '01 05:05' DAY_MINUTE): 2014-01-08 18:55:00
DATE_SUB('2014-01-10', INTERVAL '01 05' DAY_HOUR): 2014-01-08 19:00:00
DATE_SUB('2014-01-10', INTERVAL '1-01' YEAR_MONTH): 2012-12-10
1 row in set