MySQL に外部キー制約を追加する具体的な方法

MySQL に外部キー制約を追加する具体的な方法

このチュートリアルの動作環境: Windows 7 システム、MySQL 8 バージョン、Dell G3 コンピュータ。

MySQL 外部キー制約 (FOREIGN KEY) はテーブルの特別なフィールドであり、主キー制約とともによく使用されます。関連付けられているリレーションシップを持つ 2 つのテーブルの場合、関連付けられているフィールドの主キーが配置されているテーブルがプライマリ テーブル (親テーブル) であり、外部キーが配置されているテーブルがセカンダリ テーブル (子テーブル) です。

外部キーは、プライマリ テーブルとセカンダリ テーブル間の関連付けを確立し、2 つのテーブルのデータを接続して、2 つのテーブルのデータの一貫性と整合性を制限するために使用されます。

外部キーを定義するときは、次の規則に従う必要があります。

  • プライマリ テーブルは、データベース内に既に存在しているか、現在作成中のテーブルである必要があります。後者の場合、マスターテーブルとスレーブテーブルは同じテーブルです。このようなテーブルは自己参照テーブルと呼ばれ、この構造は自己参照整合性と呼ばれます。
  • 主テーブルには主キーを定義する必要があります。
  • 主キーには null 値を含めることはできませんが、外部キーには null 値が許可されます。つまり、外部キーの null 以外の値がすべて指定された主キーに表示されている限り、この外部キーの内容は正しいことになります。
  • メイン テーブルのテーブル名の後に列名または列名の組み合わせを指定します。この列または列の組み合わせは、主テーブルの主キーまたは候補キーである必要があります。
  • 外部キーの列数は、主テーブルの主キーの列数と同じである必要があります。
  • 外部キー列のデータ型は、主テーブルの主キー内の対応する列のデータ型と同じである必要があります。

MySQLのテーブルに外部キー制約を追加する

外部キー制約はテーブルを変更するときに追加できますが、外部キー制約を追加するための前提条件は、スレーブ テーブルの外部キー列のデータがマスター テーブルの主キー列のデータと一致しているか、データが存在しないことです。

データ テーブルを変更するときに外部キー制約を追加するための構文は次のとおりです。

ALTER TABLE <テーブル名> ADD CONSTRAINT <外部キー名>
FOREIGN KEY(<列名>) REFERENCES <主テーブル名> (<列名>);

データテーブル tb_emp2 を変更し、フィールド deptId を外部キーとして設定し、データテーブル tb_dept1 の主キー ID に関連付けます。

mysql> テーブル tb_emp2 を変更します
-> 制約 fk_tb_dept1 を追加
-> 外部キー(部門ID)
-> 参照 tb_dept1(id);
クエリは正常、影響を受けた行は 0 行 (1.38 秒)
レコード: 0 重複: 0 警告: 0
mysql> SHOW CREATE TABLE tb_emp2\G
************************** 1. 行 ****************************
テーブル: tb_emp2
テーブルの作成: CREATE TABLE `tb_emp2` (
`id` int(11) NULLではない、
`name` varchar(30) デフォルト NULL,
`deptId` int(11) デフォルト NULL,
`salary` float デフォルト NULL、
主キー (`id`)、
キー `fk_tb_dept1` (`deptId`)、
制約 `fk_tb_dept1` 外部キー (`deptId`) 参照 `tb_dept1` (`id`)
) エンジン=InnoDB デフォルト文字セット=gb2312
セット内1列(0.12秒)

注意: すでに作成されているデータ テーブルに外部キー制約を追加する場合は、外部キー制約が追加される列の値がすべて主キー列からのものであり、外部キー列が空であってはならないことを確認してください。

コンテンツ拡張子:

外部キー制約を使用する場合

正直に言うと、MySQL で InnoDB テーブルを使用する場合、必ずしも外部キー制約を使用する必要はありません。ただし、いくつかのケースでの外部キー制約の機能を説明するために、上記の例のコードを使用して詳しく説明します。これには、ブログ投稿を保存するためのものとコメントを保存するためのものの 2 つの MyISAM テーブルが含まれています。

データベース スキーマを定義するときに、コメント テーブルに外部キーを作成して各行 (コメント) を特定のブログ投稿にマッピングすることにより、これら 2 つのテーブル間に 1 対多の関係を確立します。サンプルの MyISAM テーブルを作成するための基本的な SQL コードは次のとおりです。

`test`.`blogs` が存在する場合はテーブルを削除します。

テーブル `test`.`blogs` を作成します (

`id` INT(10) 符号なしAUTO_INCREMENT、

`title` テキスト、

`content` テキスト、

`author` VARCHAR(45) デフォルト NULL,

PRIROSE キー (`id`)

)ENGINE=MyISAM デフォルト文字セット=utf8;


`test`.`comments` が存在する場合はテーブルを削除します。

テーブル `test`.`comments` を作成します (

`id` INT(10) 符号なしAUTO_INCREMENT、

`blog_id` INT(10) UNSIGNED デフォルト NULL,

`コメント` テキスト、

`author` VARCHAR(45) デフォルト NULL,

PRIROSE キー (`id`)

)ENGINE=MyISAM デフォルト文字セット=utf8;

これで、MySQL に外部キー制約を追加する具体的な方法についての記事は終了です。MySQL に外部キー制約を追加する方法の詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL で外部キー制約を作成および削除する方法
  • MySQL データベースの制約とデータ テーブルの設計原則
  • MySQLデータベースで外部キー制約を使用する必要があるかどうかの詳細な説明
  • MySQL 学習: データベース テーブルの 5 つの主要な制約を初心者向けに詳しく説明します
  • MySQL の 6 つの一般的な制約タイプの詳細な説明
  • MYSQLの主キー制約とユニーク制約の違いについて簡単に説明します。
  • MySQL 制約の超詳細な説明
  • MySQL の null 制約のケースの説明
  • MySQLデータベースのテーブルに制約を設定する方法

<<:  インタラクティブな視覚化 JS ライブラリ gojs の使い方の紹介とヒント

>>:  HTMLからPDFへの変換のための純粋なクライアント側と純粋なサーバー側の実装ソリューション

推薦する

CSS でフローティングにより親要素の高さが崩れる問題を解決するいくつかの方法

以前は、フロートはレイアウトによく使用されていましたが、フローティングレイアウトを使用すると親要素の...

Mysql Explainコマンドの使用と分析

mysql explain コマンドは、MySQL がインデックスを使用して選択ステートメントを処理...

Windows で負荷分散に Nginx+Tomcat を使用するための完全な手順

序文今日は、Prince が Windows で負荷分散に Nginx + Tomcat を使用する...

Nginx の負荷分散構成、ダウンタイム発生時の自動切り替えモード

厳密に言えば、nginx には負荷分散バックエンド ノードのヘルス チェック機能はありませんが、デフ...

CentOS7 ファイアウォールとポート関連コマンドの紹介

目次1. ファイアウォールの現在の状態を確認する2. ファイアウォールサービスを開始する3. ファイ...

Tomcat8はcronologを使用してCatalina.Outログを分割します

背景tomcat によって生成された catalina.out ログ ファイルが分割されていない場合...

CSS で実装された円形のプログレスバー

成果を達成する 実装コードhtml <div class="wrap"&g...

Docker で SVN サーバーを構築するチュートリアル

SVN は Subversion の略称で、ブランチ管理システムを使用して効率的に管理するオープンソ...

MySQL binlog_ignore_dbパラメータの具体的な使用法

序文:前の記事を読んだ後、binlog はデータベースで実行されたすべての DDL および DML ...

mysql-8.0.15-winx64 解凍バージョンのインストールチュートリアルと終了する 3 つの方法

1.公式サイトからダウンロードして解凍する参考: 2. 環境変数を設定するMYSQL_HOMEをMy...

Doubanウェブサイトのウェブサイトコンテンツに小さな変更を加える方法

<br />読みやすさはウェブサイトにとって非常に重要な部分であり、ウェブサイトの核心と...

Windows 上で Nginx+Tomcat クラスタを実装するプロセスの分析

導入: Nginx (エンジン エックスと同じ発音) は、BSD のようなプロトコルに基づいてリリー...

フォーム送信の更新ページはソースコード設計にジャンプしません

1. ソースコードの設計コードをコピーコードは次のとおりです。 <!DOCTYPE html ...

@Font-face の基本的な使い方と、すべてのブラウザと互換性を持たせる方法

@Font-face 基本紹介: @font-face は、Web ページにカスタム フォントを表示...

検証例 MySQL | 同じ値を持つフィールドを更新すると、binlog に記録されます

1. はじめに数日前、開発仲間から、フィールドを同じ値に更新すると binlog が記録されるかどう...