ホームページ > データベース > mysql チュートリアル > MySQL で DATE カラムのデフォルト値として CURRENT_DATE/CURDATE() を使用できないのはなぜですか?

MySQL で DATE カラムのデフォルト値として CURRENT_DATE/CURDATE() を使用できないのはなぜですか?

Linda Hamilton
リリース: 2024-12-04 21:18:12
オリジナル
194 人が閲覧しました

Why Can't I Use CURRENT_DATE/CURDATE() as a Default Value for DATE Columns in MySQL?

DATE カラムの DEFAULT 値の CURRENT_DATE/CURDATE(): 機能と制限

MySQL では、必要な状況が発生する可能性があります。 CURRENT_DATE を使用して DATE 列のデフォルト値を設定するか、 CURDATE() 関数。ただし、このアプローチは失敗することが多く、なぜサポートされないのかという疑問が生じます。

その答えは、MySQL のデフォルト値の制限にあります。 MySQL のドキュメントによると:

The DEFAULT clause specifies a default value for a column. With one exception, the default value must be a constant; it cannot be a function or an expression.
ログイン後にコピー

したがって、MySQL では、CURRENT_DATE または CURDATE() を DATE カラムのデフォルト値として使用することはできません。これらの関数は現在の日付を動的に返すためです。代わりに、デフォルト値は静的定数である必要があります。

ただし、MySQL 8.0.13 以降では、この制限は削除されています。 DATE 列のデフォルト値として CURRENT_DATE または CURDATE() を使用できるようになりました。

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

この変更により、現在の日付を DATE 列のデフォルト値として割り当てることが可能になり、より柔軟な設定が可能になります。データ管理。

以上がMySQL で DATE カラムのデフォルト値として CURRENT_DATE/CURDATE() を使用できないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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