日、月、または年が省略された文字列 - Advanced SQL Engine - Teradata Database

Teradata Vantage™ - データ タイプおよびリテラル

Product
Advanced SQL Engine
Teradata Database
Release Number
17.05
17.00
Published
2020年6月
Language
日本語
Last Update
2021-03-30
dita:mapPath
ja-JP/zsn1556242031050.ditamap
dita:ditavalPath
ja-JP/zsn1556242031050.ditaval
dita:id
B035-1143
Product Category
Software
Teradata Vantage

文字からDATEに変換される文字列と書式で日、月、または年が省略されている場合、システムはターゲットのDATE値のデフォルト値を使用します。

文字列から省略されているもの システムが使用する値
値1 (月の最初の日)。
値1 (1月)。
現在の年(現在のセッションのタイムゾーンで)

次のテーブルについて考察します。

CREATE TABLE date_log
   (id INTEGER
   ,start_date DATE
   ,end_date DATE
   ,log_date DATE);

次のINSERT文は、3つの文字列をDATE値に変換します。最初の文字列では日が省略され、2番目と3番目の文字列ではそれぞれ、月と年が省略されています。現在は1992年であると仮定しましょう。

INSERT date_log
   (1001
   ,CAST ('January 1992' AS DATE FORMAT 'MMMMBYYYY')
   ,CAST ('1992-01' AS DATE FORMAT 'YYYY-DD')
   ,CAST ('01/01' AS DATE FORMAT 'MM/DD'));

INSERT文の結果は、以下のようになります。

SELECT * FROM date_log;
         id  start_date  end_date  log_date
-----------  ----------  --------  --------
       1001    92/01/01  92/01/01  92/01/01