すべてのプロダクト
Search
ドキュメントセンター

MaxCompute:TO_DATE

最終更新日:Feb 13, 2025

指定されたformatに準拠した文字列を標準の日付値に変換します。

コマンド構文

DATETIME|DATE TO_DATE(STRING <date>[, STRING <format>])

パラメータ説明

パラメーター

必須 / 任意

説明

date

はい

STRING型、形式を満たす日付値。 入力値がBIGINT、DOUBLE、DECIMAL、またはDATETIME型の場合、値は計算前に暗黙的にSTRINGに変換されます。 この関数は、ISO 8601形式の日付文字列もサポートします。

format

いいえ

STRING型の定数。 このパラメータは、日付形式を指定します。 formatは日付拡張形式をサポートしていません。 他の文字は、解析中に無駄な文字として無視されます。

説明
  • 少なくともyyyyを含める必要があり、1回のみ表示できます。 それ以外の場合はNULLが返されます。

  • yyyy: 4桁年、mm: 2桁月、dd: 2桁日、hh: 24時間フォーマット時、mi: 2桁分、ss: 2桁秒、ff3: 3桁ミリ秒。

戻り値の説明

この関数は、DATEまたはDATETIME型の値を返します。

  • formatパラメーターなしで関数を呼び出すと、yyyy-mm-dd形式のDATE型の値が返されます。

  • formatパラメーターを指定して関数を呼び出すと、yyyy-mm-dd hh:mi:ss形式のDATETIME型の値が返されます。

  • dateまたはformatの値がNULLの場合、関数はNULLを返します。

使用例

静的データの例

-- Returns 2025-01-29
SELECT TO_DATE('2025-01-29');

-- Returns 2025-01-27 00:00:00
SELECT TO_DATE('Alibaba2025-01*27', 'Alibabayyyy-mm*dd');

-- Returns 2025-01-12 00:00:00
SELECT TO_DATE('20250112', 'yyyymmdd');

-- Returns 2025-01-28 12:12:00
SELECT TO_DATE('202501281212', 'yyyymmddhhmi');

-- Returns NULL. '2025112' cannot be converted to a standard date value, causing an error. It should be '20250112'
SELECT TO_DATE('2025112', 'yyyymmdd');

-- Returns NULL. 'Alibaba2025-12*3' cannot be converted to a standard date value, causing an error. It should be 'Alibaba2025-12*03'.
SELECT TO_DATE('Alibaba2025-12*3', 'Alibabayyyy-mm*dd');

-- Returns NULL. '2025-24-01' cannot be converted to a standard date value, causing an error. It should be '2025-01-24'.
SELECT TO_DATE('2025-24-01', 'yyyy');

-- Returns 2025-10-30 15:13:12
SELECT TO_DATE('20251030 15-13-12.345','yyyymmdd hh-mi-ss.ff3');

-- Returns NULL.
SELECT TO_DATE(NULL, 'yyyymmdd hh-mi-ss.ff3');

-- Returns NULL.
SELECT TO_DATE('20251030 15-13-12.345', NULL);

-- Returns ISO 8601 format, 2025-09-24 13:39:34
SELECT TO_DATE('2025-09-24T13:39:34.119Z', 'yyyy-MM-ddThh:mi:ss.ff3Z');

テーブルデータの例

  1. データの例。

    CREATE TABLE IF NOT EXISTS mf_date_fun_t(
        id      INT,
        date1   DATE,
        datetime1   DATETIME,
        timestamp1 TIMESTAMP,
        date2   DATE,
        datetime2   DATETIME,
        timestamp2 TIMESTAMP,
        date3 STRING,
        date4 BIGINT);
    
    INSERT INTO mf_date_fun_t VALUES 
    (1,DATE'2021-11-29',DATETIME'2021-11-29 00:01:00',TIMESTAMP'2021-01-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-20',123456780),
    (2,DATE'2021-11-28',DATETIME'2021-11-28 00:02:00',TIMESTAMP'2021-02-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-21',123456781),
    (3,DATE'2021-11-27',DATETIME'2021-11-27 00:03:00',TIMESTAMP'2021-03-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-22',123456782),
    (4,DATE'2021-11-26',DATETIME'2021-11-26 00:04:00',TIMESTAMP'2021-04-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-23',123456783),
    (5,DATE'2021-11-25',DATETIME'2021-11-25 00:05:00',TIMESTAMP'2021-05-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-24',123456784),
    (6,DATE'2021-11-24',DATETIME'2021-11-24 00:06:00',TIMESTAMP'2021-06-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-25',123456785),
    (7,DATE'2021-11-23',DATETIME'2021-11-23 00:07:00',TIMESTAMP'2021-07-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-26',123456786),
    (8,DATE'2021-11-22',DATETIME'2021-11-22 00:08:00',TIMESTAMP'2021-08-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-27',123456787),
    (9,DATE'2021-11-21',DATETIME'2021-11-21 00:09:00',TIMESTAMP'2021-09-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-28',123456788),
    (10,DATE'2021-11-20',DATETIME'2021-11-20 00:10:00',TIMESTAMP'2021-10-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-29',123456789);
  2. STRINGタイプdate3フィールドをDATETIMEタイプdate3_to_dateに変換して出力します。

    SELECT date3, TO_DATE(date3, 'yyyy-mm-dd') AS date3_to_date FROM mf_date_fun_t;

    次の結果が返されます。

    +------------+---------------------+
    | date3      | date3_to_date       |
    +------------+---------------------+
    | 2021-11-20 | 2021-11-20 00:00:00 |
    | 2021-11-21 | 2021-11-21 00:00:00 |
    | 2021-11-22 | 2021-11-22 00:00:00 |
    | 2021-11-23 | 2021-11-23 00:00:00 |
    | 2021-11-24 | 2021-11-24 00:00:00 |
    | 2021-11-25 | 2021-11-25 00:00:00 |
    | 2021-11-26 | 2021-11-26 00:00:00 |
    | 2021-11-27 | 2021-11-27 00:00:00 |
    | 2021-11-28 | 2021-11-28 00:00:00 |
    | 2021-11-29 | 2021-11-29 00:00:00 |
    +------------+---------------------+

関連関数

TO_DATE関数は、日付関数のスイートの一部です。 日付の計算と変換関数の詳細については、日付関数.をご参照ください。