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

MySQL DATE カラムのデフォルト値として CURRENT_DATE を設定できないのはなぜですか?

Patricia Arquette
リリース: 2024-12-16 13:16:11
オリジナル
419 人が閲覧しました

Why Can't I Set CURRENT_DATE as the Default Value for a MySQL DATE Column?

CURRENT_DATE デフォルト値パズル

MySQL では、DATE カラムのデフォルト値を CURDATE() または CURRENT_DATE に設定しようとすると、次のように見えるかもしれません。直感的な選択。ただし、そのようなテーブルを作成しようとすると、機能しません。この質問では、この動作が発生する理由について説明します。

原因は、MySQL の DEFAULT 句の制限にあります。公式ドキュメントで説明されているように:

「DEFAULT 句は列のデフォルト値を指定します。1 つの例外を除いて、デフォルト値は定数でなければなりません。関数や式は使用できません。」

したがって、現在の日付を取得する関数である CURRENT_DATE を DATE 列のデフォルトとして割り当てることはできません。

例外

このルールの例外は、CURRENT_TIMESTAMP 列タイプです。 TIMESTAMP 列の場合、デフォルト値として CURRENT_TIMESTAMP を指定すると、列に現在の日付と時刻が自動的に入力されます。

回避策

DATE 列の現在の日付と時刻を使用すると、トリガーを使用して、挿入および更新操作時にフィールドを自動的に更新できます。

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

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