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

Date型リテラル

説明

標準SQLと一致して、Dorisでは日付リテラルを指定するためにタイプキーワードと文字列の使用が必要です。キーワードと文字列の間のスペースはオプションです。例えば:

DATE '2008-08-08'
TIMESTAMP '2008-08-08 20:08:08'

日付形式

DATE リテラル

  • 'YYYY-MM-DD'または'YY-MM-DD'の形式で-で区切られた文字列を使用します。Dorisは MySQL の非標準区切り文字形式もサポートしていますが、その使用は推奨されません。
  • 区切り文字なしの文字列として、'YYYYMMDD'または'YYMMDD'の形式を使用します(文字列が日付として意味がある場合)。

DATETIME リテラル

  • 'YYYY-MM-DD hh:mm:ss'または'YY-MM-DD hh:mm:ss'の形式で-で区切られた文字列を使用します。Dorisは MySQL の非標準区切り文字形式もサポートしていますが、その使用は推奨されません。日付と時間の間の区切り文字は、スペース( )またはTを使用できます。MySQL 8.4およびそれ以前のバージョンとは異なり、Dorisは時間と日付の間の他の区切り文字をサポートしていません。
  • 区切り文字なしの文字列として、'YYYYMMDDhhmmss'または'YYMMDDhhmmss'の形式を使用します(文字列が日付として意味がある場合)。

DATETIME リテラルには、マイクロ秒(6桁)までの精度で小数秒部分を含めることができます。小数部分は常に時間の残りの部分からドット(.)で区切る必要があります。その他の小数秒区切り文字は認識されません。

2桁の年

2桁の年の値を含む日付は、世紀が不明であるため曖昧です。Dorisは2桁の年の値を解釈するために以下のルールを使用します:

  • 70-99の年の値は1970-1999年として解釈されます。
  • 00-69の年の値は2000-2069年として解釈されます。

タイムゾーン

DATEおよびDATETIME リテラルは、タイムゾーン接尾辞を使用できます。タイムゾーンを使用する場合、タイムゾーンは前の日付または時間部分に直接隣接している必要があり、間にスペースを入れてはいけません。例えば:

TIMESTAMP '2008-08-08 20:08:08+08:00'

Dorisがサポートするタイムゾーン形式は以下の通りです:

  • タイムゾーンオフセット:形式は{+ | -}hh:mmです。例えば、UTC+8の場合は+08:00となります。
  • タイムゾーン名。例えば、上海のタイムゾーンはAsia/Shanghaiです。

無効な値の処理

有効な日付リテラルに解析できない値に遭遇した場合、Dorisは直接エラーを報告します。例えば:

SELECT date '071332'

次のエラーが発生します:

date/datetime literal [071332] is invalid