ホームページ >データベース >mysql チュートリアル >「外部キー制約で使用されている列を変更できません」エラーを解決するにはどうすればよいですか?
テーブルを変更しようとすると、「列 'column_name' を変更できません」というエラーが発生する場合があります。 : 外部キー制約で使用されています。」このエラーは、変更中の列が別のテーブルの外部キーとして参照されている場合に発生します。
あなたの特定のケースでは、person テーブルの person_id 列を変更しようとしました。この列は、お気に入りの食べ物テーブル。これにより、参照される列の定義を変更すると外部キー制約の整合性が損なわれる可能性があるため、依存関係の問題が発生します。
この問題を解決するには、外部キーのチェックを一時的に無効にします。
SET FOREIGN_KEY_CHECKS = 0;
この一時停止により、外部キー制約に違反することなく、列に必要な変更を加えることができます。ただし、後で外部キー チェックを再度有効にすることが重要です:
SET FOREIGN_KEY_CHECKS = 1;
注意: 外部キー チェックの無効化は高度な操作であり、注意して実行する必要があります。データベースが一時的にデータ整合性の問題にさらされる可能性があります。このような操作を実行する前に、必ず最新のバックアップがあることを確認してください。
以上が「外部キー制約で使用されている列を変更できません」エラーを解決するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。