ホームページ > データベース > mysql チュートリアル > MySQL で「DEFAULT CURRENT_DATE」が機能しないのはなぜですか (そしていつ機能するのですか?)

MySQL で「DEFAULT CURRENT_DATE」が機能しないのはなぜですか (そしていつ機能するのですか?)

Barbara Streisand
リリース: 2024-12-10 06:19:14
オリジナル
356 人が閲覧しました

Why Doesn't `DEFAULT CURRENT_DATE` Work in MySQL (and When Does It?)

デフォルトの DATE 値としての CURRENT_DATE/CURDATE() の修正

見た目は単純ですが、CURRENT_DATE または CURDATE() をデフォルト値として設定します。以下の構文を使用する DATE 列は使用できない場合があります。 function:

CREATE TABLE INVOICE(
   INVOICEDATE DATE NOT NULL DEFAULT CURRENT_DATE
)
ログイン後にコピー

Reason:

このコードは直感的に見えるかもしれませんが、MySQL の制限により失敗します。ドキュメントによると、DEFAULT 句では列に定数値を指定する必要があります。 CURRENT_DATE などの関数または式は許可されません。

解決策:

以前、この問題は 8.0.13 より前の MySQL バージョンでも発生していました。ただし、MySQL 8.0.13 以降では、DATE カラムのデフォルト値として CURRENT_DATE() または CURDATE() を使用できるため、回避策は必要ありません。

以上がMySQL で「DEFAULT CURRENT_DATE」が機能しないのはなぜですか (そしていつ機能するのですか?)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート