MariaDBの日時式から1秒以上を減算するためのいくつかのオプションを次に示します。
SUBTIME()
機能
SUBTIME()
時間または日時の値から指定された時間を減算します。
例:
SELECT SUBTIME('2021-05-01 10:00:00', '00:00:30');
結果:
+--------------------------------------------+ | SUBTIME('2021-05-01 10:00:00', '00:00:30') | +--------------------------------------------+ | 2021-05-01 09:59:30 | +--------------------------------------------+
時間、分など、他の時間単位を変更することもできます。
DATE_SUB()
機能
DATE_SUB()
関数を使用すると、日付または日時式から特定の数の日付/時刻単位を減算できます。したがって、この関数を使用して、特定の秒数を引いた日時の値を返すことができます。
例:
SELECT DATE_SUB('2021-05-01 10:00:00', INTERVAL 30 SECOND);
結果:
+-----------------------------------------------------+ | DATE_SUB('2021-05-01 10:00:00', INTERVAL 30 SECOND) | +-----------------------------------------------------+ | 2021-05-01 09:59:30 | +-----------------------------------------------------+
SECOND
に注意してください 1秒以上減算するかどうかに関係なく、キーワードは複数形のままです。
日付と時刻の複合単位を使用することもできます。たとえば、数分と数秒をすべて一度に実行できます。
例:
SELECT DATE_SUB('2021-05-01 10:00:00', INTERVAL '15:30' MINUTE_SECOND);
結果:
+-----------------------------------------------------------------+ | DATE_SUB('2021-05-01 10:00:00', INTERVAL '15:30' MINUTE_SECOND) | +-----------------------------------------------------------------+ | 2021-05-01 09:44:30 | +-----------------------------------------------------------------+
日付だけを渡す
日付の値だけを指定すると、次のようになります。
SELECT DATE_SUB('2021-05-01', INTERVAL 30 SECOND);
結果:
+--------------------------------------------+ | DATE_SUB('2021-05-01', INTERVAL 30 SECOND) | +--------------------------------------------+ | 2021-04-30 23:59:30 | +--------------------------------------------+
時刻は00:00:00から始まると想定しているため、SECOND
そこから金額が差し引かれます。
減算演算子(-
)
日時の値から1秒以上を減算する別の方法は、減算演算子(-
)を使用することです。 )、マイナス演算子とも呼ばれます。
例:
SELECT '2021-05-01 10:00:00' - INTERVAL 30 SECOND;
結果:
+--------------------------------------------+ | '2021-05-01 10:00:00' - INTERVAL 30 SECOND | +--------------------------------------------+ | 2021-05-01 09:59:30 | +--------------------------------------------+
加算演算子(+
)
または、加算演算子(+
)を使用することもできます。 )負の金額と一緒に。
例:
SELECT '2021-05-01 10:00:00' + INTERVAL -30 SECOND;
結果:
+---------------------------------------------+ | '2021-05-01 10:00:00' + INTERVAL -30 SECOND | +---------------------------------------------+ | 2021-05-01 09:59:30 | +---------------------------------------------+
秒を引く他の方法
日時の値から1秒以上を引くために使用できる他のアプローチは次のとおりです。
-
SUBTIME()
機能。 -
ADDTIME()
関数(負の金額を指定すると、日時の値からその金額が差し引かれます)。 -
SUBDATE()
関数(これはDATE_SUB()
の同義語です 同じ構文で使用した場合) -
DATE_ADD()
関数(負の金額を指定すると、日時の値からその金額が差し引かれます)。 -
ADDDATE()
関数(負の金額を指定すると、日時の値からその金額が差し引かれます)。