MICROSECONDS_SUB
説明
MICROSECONDS_SUB関数は、入力されたdatetime値から指定されたマイクロ秒数を減算し、結果として得られる新しいdatetime値を返します。この関数は、マイクロ秒精度でDATETIMEおよびTIMESTAMPTZ型の処理をサポートします。
この関数は、MICROSECONDを単位として使用する場合、MySQLのdate_sub functionと同じ動作をします。
構文
MICROSECONDS_SUB(`<datetime_like_type>`, `<delta>`)
パラメータ
| パラメータ | 説明 |
|---|---|
<datetime_like_type> | 入力する日時値。DATETIMEまたはTIMESTAMPTZ型。具体的なフォーマットについては、timestamptz conversion、datetime conversionを参照してください。 |
<delta> | 減算するマイクロ秒数。BIGINT型。1秒 = 1,000,000マイクロ秒。 |
戻り値
基準時刻<datetime_like_type>から指定されたマイクロ秒数<delta>を減算した結果を返します。戻り値の型は第1パラメータの型と同じです。
<delta>が負の値の場合、基準時刻に対応するマイクロ秒数を加算するのと同じ動作になります(つまり、MICROSECONDS_SUB(basetime, -n)はMICROSECONDS_ADD(basetime, n)と同等です)。- 計算結果が
DATETIME型の有効範囲(0000-01-01 00:00:00から9999-12-31 23:59:59.999999)を超える場合、例外がスローされます。 - いずれかのパラメータが
NULLの場合、関数はNULLを返します。
例
-- Subtract microseconds
SELECT NOW(3) AS current_time, MICROSECONDS_SUB(NOW(3), 100000) AS after_sub;
+-------------------------+----------------------------+
| current_time | after_sub |
+-------------------------+----------------------------+
| 2025-01-16 11:52:22.296 | 2025-01-16 11:52:22.196000 |
+-------------------------+----------------------------+
-- Negative delta (equivalent to addition)
mysql> SELECT MICROSECONDS_SUB('2023-10-01 12:00:00.200000', -300000) AS after_sub;
+----------------------------+
| after_sub |
+----------------------------+
| 2023-10-01 12:00:00.500000 |
+----------------------------+
-- Any parameter is NULL, returns NULL
SELECT MICROSECONDS_SUB(NULL, 1000), MICROSECONDS_SUB('2023-01-01', NULL) AS after_sub;
+------------------------------+----------------------------+
| microseconds_sub(NULL, 1000) | after_sub |
+------------------------------+----------------------------+
| NULL | NULL |
+------------------------------+----------------------------+
-- Input type is DATE, time part is automatically set to 00:00:00.000000
SELECT MICROSECONDS_SUB('2023-10-01', -300000);
+-----------------------------------------+
| MICROSECONDS_SUB('2023-10-01', -300000) |
+-----------------------------------------+
| 2023-10-01 00:00:00.300000 |
+-----------------------------------------+
-- Example of TimeStampTz type, SET time_zone = '+08:00'
SELECT MICROSECONDS_SUB('2024-12-25 12:34:56.123+04:00', '765800');
+-------------------------------------------------------------+
| MICROSECONDS_SUB('2024-12-25 12:34:56.123+04:00', '765800') |
+-------------------------------------------------------------+
| 2024-12-25 16:34:55.357200+08:00 |
+-------------------------------------------------------------+
-- Exceeds datetime range, throws an error
mysql> SELECT MICROSECONDS_SUB('0000-01-01 00:00:00.000000', 1000000) AS after_sub;
ERROR 1105 (HY000): errCode = 2, detailMessage = (10.16.10.3)[E-218]Operation microseconds_add of 0000-01-01 00:00:00, -1000000
out of range