mysql外部キーを削除する

WBOY
WBOYオリジナル
2023-05-18 14:10:373746ブラウズ

MySQL の外部キーを削除する方法

MySQL では、外部キーはデータの整合性と一貫性を保証する重要な概念です。外部キーを削除する必要がある場合は、いくつかの詳細に注意する必要があります。この記事では、MySQL で外部キーを削除する方法を紹介し、発生する可能性のあるいくつかの問題について説明します。

ステップ 1: 既存の外部キーを表示する

MySQL では、次のステートメントを通じて既存の外部キーを表示できます:

SHOW CREATE TABLE table_name;

その中で、table_name が表示されます。外部キーの名前。このステートメントを実行すると、MySQL はテーブル構造を含む結果セットを返します。結果セットには外部キーの定義が含まれています。たとえば、次の例の外部キー名は fk_order_customer で、orders テーブルの customer_id フィールドと テーブルの ## を結合します。顧客テーブル#idフィールド。

CREATE TABLE `orders` (
  `id` int(11) NOT NULL,
  `customer_id` int(11) NOT NULL,
  `order_number` varchar(45) NOT NULL,
  PRIMARY KEY (`id`),
  KEY `fk_order_customer` (`customer_id`),
  CONSTRAINT `fk_order_customer` FOREIGN KEY (`customer_id`) REFERENCES `customers` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

ステップ 2: 外部キーを削除する

外部キーを削除するには 2 つの方法があります。

方法 1: ALTER TABLE ステートメントを使用する

ALTER TABLE ステートメントを使用して外部キーを削除できます。構文は次のとおりです。

ALTER TABLE table_name DROP FOREIGN KEY foreign_key_name;

このうち、table_nameは外部キーを削除するテーブルの名前、foreign_key_nameは削除する外部キーの名前です。たとえば、次のステートメントは、上記の例の

fk_order_customer 外部キーを削除します。

ALTER TABLE orders DROP FOREIGN KEY fk_order_customer;

方法 2: DROP INDEX ステートメントを使用する

DROP ステートメントを使用することもできます。 INDEX ステートメントを使用して外部キー key を削除します。構文は次のとおりです。

ALTER TABLE table_name DROP INDEX index_name;

このうち、table_nameは外部キーを削除するテーブルの名前、index_nameは削除する外部キーの名前です。たとえば、次のステートメントは、上記の例の

fk_order_customer 外部キーを削除します。

ALTER TABLE orders DROP INDEX fk_order_customer;

両方のメソッドを使用して外部キーを削除できます。ただし、外部キーの定義方法 (MySQL では「制約」と呼ばれます) に応じて、別のアプローチを使用する必要があります。

外部キーが「外部キー制約」(「リレーションシップ制約」とも呼ばれる)として定義されている場合は、ALTER TABLE ステートメントを使用して外部キーを削除する必要があります。上記の例では、外部キーは「外部キー制約」として定義されているため、ALTER TABLE ステートメントを使用して削除します。

外部キーが「インデックス制約」として定義されている場合、DROP INDEX ステートメントを使用して外部キーを削除できます。 MySQL では、インデックス制約は「外部キー インデックス」によって自動的に生成されます。外部キーインデックスのみを削除し、外部キー制約を削除しない場合、外部キーはまだ存在しますが、バインディングではなくなることに注意してください。この場合、ALTER TABLE ステートメントを使用して外部キー制約自体を削除する必要がある場合があります。

ステップ 3: 削除操作を確認する

削除操作を実行する前に、まず削除操作が既存のデータに影響を与えるかどうかを確認する必要があります。たとえば、外部キー制約を削除すると、データの整合性に違反したり、削除が失敗したり、データの一貫性が損なわれたりする可能性があります。

削除操作を確認するためのヒントをいくつか示します:

    依存関係があるかどうかを確認する
上記の例では、必要な外部キーがdelete この制約は、

orders テーブルの customer_id フィールドと customers テーブルの id フィールドを接続します。これは、orders テーブルの customer_id フィールドが、customers テーブルの id フィールドを参照することを意味します。外部キー制約を削除すると、orders テーブルの customer_id フィールドは、customers テーブルの id フィールドを参照する可能性があります。存在しません。これは許可されません。

したがって、外部キー制約を削除する前に、

orders テーブルによって参照されるレコードが customers テーブルに存在しないことを確認する必要があります。簡単な方法は、次のステートメントで確認することです。

SELECT * FROM customers WHERE id NOT IN (SELECT customer_id FROM orders);

このステートメントが空の結果セットを返す場合、# によって参照される

customers テーブルには何も存在しないことを意味します。 ##orders テーブル レコードでは、外部キー制約を安全に削除できます。それ以外の場合は、まず customers テーブル内の存在しないレコードを参照する orders テーブル内の行を削除してから、外部キー制約を削除する必要があります。

カスケード操作の確認
  1. 上記の例では、外部キー制約によってカスケード削除操作とカスケード更新操作が定義されています。これは、
customers

テーブル内のレコードを削除または更新すると、そのレコードを参照する orders テーブル内のすべての行も削除または更新されることを意味します。したがって、外部キー制約を削除する前に、カスケード操作の影響を考慮する必要があります。 ここにいくつかの提案があります:

カスケード操作によって悪影響が生じる可能性がある場合は、まずテーブル内のすべての関連する
    orders
  • 行を手動で削除または更新します。次に、外部キー制約を削除します。 カスケード操作を保持したい場合は、必要に応じて復元できるように、外部キー制約を削除する前に関連データをバックアップできます。
  • 概要

MySQL の外部キーの削除は一般的な操作であり、いくつかの詳細が含まれています。 ALTER TABLE ステートメントまたは DROP INDEX ステートメントを使用して外部キーを削除できますが、外部キーがどのように定義されているかに注意する必要があります。削除操作を実行する前に、特に依存関係とカスケード操作の観点から、削除操作が既存のデータに影響を与えるかどうかを確認する必要があります。

以上がmysql外部キーを削除するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。