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

MILLISECOND_TIMESTAMP

説明

MILLISECOND_TIMESTAMP関数は、入力された日時の値を1970-01-01 00:00:00から計算されたUnixタイムスタンプに変換します(ローカルタイムゾーンオフセットで調整)。単位はミリ秒です(1秒 = 1,000ミリ秒)。この関数は、ミリ秒精度を持つDATETIME型の処理をサポートし、変換時にタイムゾーンの違いを自動的に無視します(デフォルトの基準としてUTC時刻を使用)。

構文

MILLISECOND_TIMESTAMP(`<datetime>`)

パラメータ

Parameterデスクリプション
<datetime>Unix タイムスタンプに変換される datetime を表します。DATETIME 型をサポートします。具体的な datetime フォーマットについては、datetime conversion を参照してください。

Return Value

入力された datetime に対応する Unix タイムスタンプをミリ秒で表す BIGINT 整数を返します(現在のタイムゾーンに変換された総ミリ秒)。タイムゾーン設定については、Time Zone Management を参照してください。

  • 入力が NULL の場合、関数は NULL を返します。
  • マイクロ秒を含む datetime 値を変換します(自動的にミリ秒に切り捨てられます)。
  • 入力された datetime が 1970-01-01 00:00:00.000 UTC より前の場合、結果は負の値になります。

Examples

-- Convert a DATETIME with millisecond precision, executed in a machine with the East 8 time zone
SELECT MILLISECOND_TIMESTAMP('2025-01-23 12:34:56.123');
+--------------------------------------------------+
| MILLISECOND_TIMESTAMP('2025-01-23 12:34:56.123') |
+--------------------------------------------------+
| 1737606896123 |
+--------------------------------------------------+

-- Explicitly specify the time zone as UTC
SELECT MILLISECOND_TIMESTAMP('2025-01-23 12:34:56.123 UTC');
+------------------------------------------------------+
| MILLISECOND_TIMESTAMP('2025-01-23 12:34:56.123 UTC') |
+------------------------------------------------------+
| 1737635696123 |
+------------------------------------------------------+

-- Convert datetime values with microseconds (automatically truncated to milliseconds)
SELECT MILLISECOND_TIMESTAMP('2024-01-01 00:00:00.123456');
+-----------------------------------------------------+
| MILLISECOND_TIMESTAMP('2024-01-01 00:00:00.123456') |
+-----------------------------------------------------+
| 1704038400123 |
+-----------------------------------------------------+

-- Specified time zone is out of range, returns NULL
SELECT MILLISECOND_TIMESTAMP('2025-01-23 12:34:56.123456 +15:00');
+------------------------------------------------------------+
| MILLISECOND_TIMESTAMP('2025-01-23 12:34:56.123456 +15:00') |
+------------------------------------------------------------+
| NULL |
+------------------------------------------------------------+

-- If the input datetime is before 1970 (standard UTC), returns a negative value
SELECT MILLISECOND_TIMESTAMP('1960-01-01 00:00:00 UTC');
+---------------------------------------------------+
| MILLISECOND_TIMESTAMP('1960-01-01 00:00:00 UTC') |
+---------------------------------------------------+
| -315619200000000 |
+---------------------------------------------------+

-- Input type is DATE, time part is automatically set to 00:00:00.000 (results are negative in East 8 time zone)
SELECT MILLISECOND_TIMESTAMP('1970-01-01');
+-------------------------------------+
| MILLISECOND_TIMESTAMP('1970-01-01') |
+-------------------------------------+
| -28800000 |
+-------------------------------------+

-- Input is NULL, returns NULL
SELECT MILLISECOND_TIMESTAMP(NULL);
+-----------------------------+
| MILLISECOND_TIMESTAMP(NULL) |
+-----------------------------+
| NULL |
+-----------------------------+