メインコンテンツまでスキップ
バージョン: 26.x

MILLISECONDS_ADD

説明

MILLISECONDS_ADD関数は、入力されたdatetime値に指定されたミリ秒数を加算し、結果として得られる新しいdatetime値を返します。この関数は、ミリ秒精度のDATETIME型の処理をサポートします。

構文

MILLISECONDS_ADD(`<datetime>`, `<delta>`)

パラメータ

パラメータ説明
<datetime>入力されるdatetime値。DATETIME型をサポートします。具体的なdatetime形式については、datetime conversionを参照してください。
<delta>追加するミリ秒数。BIGINT型です。1秒 = 1,000ミリ秒 = 1,000,000マイクロ秒。

戻り値

DATETIME型の値を返します。これは基準時刻に指定されたミリ秒を追加した結果を表します。

  • <delta>が負の場合、この関数は基準時刻から対応するミリ秒を減算するのと同じ動作をします(つまり、MILLISECONDS_ADD(basetime, -n)MILLISECONDS_SUB(basetime, n)と同等です)。
  • 入力がDATE型の場合(年、月、日のみを含む)、デフォルトの時刻部分は00:00:00.000に設定されます。
  • 計算結果がDATETIME型の有効範囲(0000-01-01 00:00:00から9999-12-31 23:59:59.999999)を超える場合、例外がスローされます。
  • いずれかのパラメータがNULLの場合、関数はNULLを返します。

-- Add one millisecond
SELECT MILLISECONDS_ADD('2023-09-08 16:02:08.435123', 1);

+---------------------------------------------------+
| MILLISECONDS_ADD('2023-09-08 16:02:08.435123', 1) |
+---------------------------------------------------+
| 2023-09-08 16:02:08.436123 |
+---------------------------------------------------+

-- Negative milliseconds, subtracts the corresponding milliseconds from the datetime
SELECT MILLISECONDS_ADD('2023-05-01 10:00:00.800', -300);
+---------------------------------------------------+
| MILLISECONDS_ADD('2023-05-01 10:00:00.800', -300) |
+---------------------------------------------------+
| 2023-05-01 10:00:00.500000 |
+---------------------------------------------------+

-- Input is of DATE type (default time is 00:00:00.000)
SELECT MILLISECONDS_ADD('2023-01-01', 1500);
+--------------------------------------+
| MILLISECONDS_ADD('2023-01-01', 1500) |
+--------------------------------------+
| 2023-01-01 00:00:01.500000 |
+--------------------------------------+

-- Calculation result exceeds the datetime range, throws an exception
SELECT MILLISECONDS_ADD('9999-12-31 23:59:59.999', 2000) AS after_add;
ERROR 1105 (HY000): errCode = 2, detailMessage = (10.16.10.3)[E-218]Operation milliseconds_add of 9999-12-31 23:59:59.999000, 2000 out of range

-- Any parameter is NULL, returns NULL
SELECT MILLISECONDS_ADD('2023-10-01 12:00:00.500', NULL) AS after_add;
+-----------+
| after_add |
+-----------+
| NULL |
+-----------+