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

UNIX_TIMESTAMP

説明

DateまたはDatetime型をunixタイムスタンプに変換します。

パラメータが提供されない場合、現在時刻がタイムスタンプに変換されます。

パラメータはDateまたはDatetime型である必要があります。

Format指定については、date_format関数のフォーマット説明を参照してください。

この関数はタイムゾーンの影響を受けます。タイムゾーンの詳細についてはTime Zone Managementを参照してください。

この関数はMySQLのunix_timestamp functionと一致しています。

構文

UNIX_TIMESTAMP()
UNIX_TIMESTAMP(`<date_or_date_expr>`)
UNIX_TIMESTAMP(`<date_or_date_expr>`, `<fmt>`)

パラメータ

Parameterデスクリプション
<date_or_date_expr>入力datetime値で、date/datetimeタイプをサポートします。datetimeとdateの形式については、datetime conversiondate conversionを参照してください
<fmt>dateパラメータはタイムスタンプに変換される特定の部分を指定し、型はstringです。このパラメータが提供される場合、形式にマッチする部分のみがタイムスタンプに変換されます。

Return Value

入力に基づいて2つのタイプを返します:

  1. 入力date_or_date_exprがゼロ以外のscaleを持つdatetimeタイプまたはformatパラメータがある場合: 最大6桁の小数点精度を持つDecimalタイプのタイムスタンプを返します

  2. 入力date_or_date_exprがscale 0でformatパラメータがない場合: INTタイプのタイムスタンプを返します

入力時刻を対応するタイムスタンプに変換します。エポック時間は1970-01-01 00:00:00です。

  • いずれかのパラメータがnullの場合、nullを返します。
  • 形式が無効な場合、エラーを返します

Examples

-- Input datetime is the begin datetime
mysql> select unix_timestamp('1970-01-01 00:00:00');
+---------------------------------------+
| unix_timestamp('1970-01-01 00:00:00') |
+---------------------------------------+
| 0 |
+------------------------------+

-- Display timestamp of current time
mysql> select unix_timestamp();
+------------------+
| unix_timestamp() |
+------------------+
| 1753933330 |
+------------------+

-- Input a datetime to display its timestamp
mysql> select unix_timestamp('2007-11-30 10:30:19');
+---------------------------------------+
| unix_timestamp('2007-11-30 10:30:19') |
+---------------------------------------+
| 1196389819 |
+---------------------------------------+


-- Match format to display timestamp for given datetime
mysql> select unix_timestamp('2007-11-30 10:30-19', '%Y-%m-%d %H:%i-%s');
+------------------------------------------------------------+
| unix_timestamp('2007-11-30 10:30-19', '%Y-%m-%d %H:%i-%s') |
+------------------------------------------------------------+
| 1196389819.000000 |
+------------------------------------------------------------+

-- Input with non-zero scale
mysql> SELECT UNIX_TIMESTAMP('2015-11-13 10:20:19.123');
+-------------------------------------------+
| UNIX_TIMESTAMP('2015-11-13 10:20:19.123') |
+-------------------------------------------+
| 1447381219.123 |
+-------------------------------------------+

-- For datetime before 1970-01-01, returns 0
select unix_timestamp('1007-11-30 10:30:19');
+---------------------------------------+
| unix_timestamp('1007-11-30 10:30:19') |
+---------------------------------------+
| 0 |
+---------------------------------------+

-- Returns NULL if any parameter is null
mysql> select unix_timestamp(NULL);
+----------------------+
| unix_timestamp(NULL) |
+----------------------+
| NULL |
+----------------------+

-- Returns an error if format is invalid
mysql> select unix_timestamp('2007-11-30 10:30-19', 's');
ERROR 1105 (HY000): errCode = 2, detailMessage = (10.16.10.3)[INVALID_ARGUMENT]Operation unix_timestamp of 2007-11-30 10:30-19, s is invalid