外部キー制約を持つテーブルを切り詰めるにはどうすればよいですか?

DDD
リリース: 2024-11-18 10:01:01
オリジナル
859 人が閲覧しました

How to Truncate a Table with Foreign Key Constraints?

TRUNCATE 操作による外部キー制約の処理

外部キー制約のあるテーブルで TRUNCATE 操作を実行すると、「」のようなエラーが発生する場合があります。外部キー制約で参照されているテーブルを切り詰めることはできません。」このエラーは、通常、TRUNCATE はテーブルからすべての行を削除しますが、外部キー制約が存在するとデータの不整合が生じる可能性があるために発生します。

たとえば、提供されたスキーマで mygroup テーブルを TRUNCATE しようとすると、の場合、インスタンス テーブルの外部キー制約により操作は失敗します。この問題に対処し、mygroup テーブルを正常に切り詰めるには、次の手順で外部キー チェックを一時的に無効にします。

SET FOREIGN_KEY_CHECKS = 0;
TRUNCATE TABLE mygroup;
TRUNCATE TABLE instance;
SET FOREIGN_KEY_CHECKS = 1;
ログイン後にコピー

外部キー チェックを無効にすることで、TRUNCATE 操作で両方のテーブルからすべての行を削除できるようになります。外部キー制約に違反することなく、mygroup テーブルとインスタンス テーブルを作成できます。ただし、アプリケーションが外部キー チェックを再度有効にする前にこれらのテーブルにデータを挿入しようとすると、データの不整合が生じる可能性があることに注意することが重要です。

したがって、このアプローチを慎重に使用し、アプリケーションが確実に外部キーのチェックが無効になっていません。 TRUNCATE 操作が完了したら、外部キー チェックを再度有効にしてデータの整合性を維持します。

以上が外部キー制約を持つテーブルを切り詰めるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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