MySQL のデフォルトの ON DELETE 動作: オプションの明確化
子テーブルで外部キー関係を持つ親行を削除するときの MySQL の動作を理解することが重要ですデータの整合性のために。 MySQL のドキュメントはやや曖昧な場合があり、デフォルトの動作に関して混乱が生じます。この記事は、ON DELETE 句で考えられる 5 つのオプションを明確に説明し、それらが省略された場合のデフォルトの動作を確立することを目的としています。
NO ACTION と RESTRICT: FK 制約の違反の防止
MySQL のデフォルトの ON DELETE 動作は NO ACTION (または RESTRICT) です。どちらのオプションも同様に機能し、外部キー制約に違反するデータベース変更を効果的に防止します。つまり、関連する子行を持つ親行を削除することは禁止されています。
SET NULL: FK 値の無効化
SET NULL オプションは、異なるアプローチを採用します。 ON DELETE SET NULL が指定されている場合、MySQL は親行の削除を許可しますが、カラムが NOT NULL として定義されていない限り、子テーブル内の対応する外部キー値を無効にします。
CASCADE: 伝播一方、関連行の削除
CASCADE は、親行が削除されたときに、関連する子行のカスケード削除を自動化します。このオプションにより、子データも削除され、データベースの参照整合性が維持されます。
SET DEFAULT: サポートされていないオプション
SET DEFAULT オプションは、パーサーですが、最終的には InnoDB によって拒否されます。これは有効なオプションではないため、回避する必要があります。
結論
要約すると、MySQL の ON DELETE 句に対するデフォルトの動作は NO ACTION または RESTRICT であり、削除が防止されます。子行を持つ親行の数。 SET NULL は子行の外部キー値を無効にし、CASCADE は関連する子行を自動的に削除します。 SET DEFAULT はサポートされていないオプションです。これらのオプションを理解することは、リレーショナル データベースでのデータ管理とデータの整合性の維持に不可欠です。
以上がMySQL で親行を削除するとどうなりますか? ON DELETE の動作とデフォルトのオプションについて理解します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。