このチュートリアルの動作環境: Windows 7 システム、MySQL 8 バージョン、Dell G3 コンピュータ。 MySQL 外部キー制約 (FOREIGN KEY) はテーブルの特別なフィールドであり、主キー制約とともによく使用されます。関連付けられているリレーションシップを持つ 2 つのテーブルの場合、関連付けられているフィールドの主キーが配置されているテーブルがプライマリ テーブル (親テーブル) であり、外部キーが配置されているテーブルがセカンダリ テーブル (子テーブル) です。 外部キーは、プライマリ テーブルとセカンダリ テーブル間の関連付けを確立し、2 つのテーブルのデータを接続して、2 つのテーブルのデータの一貫性と整合性を制限するために使用されます。 外部キーを定義するときは、次の規則に従う必要があります。
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 をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: インタラクティブな視覚化 JS ライブラリ gojs の使い方の紹介とヒント
>>: HTMLからPDFへの変換のための純粋なクライアント側と純粋なサーバー側の実装ソリューション
以前は、フロートはレイアウトによく使用されていましたが、フローティングレイアウトを使用すると親要素の...
mysql explain コマンドは、MySQL がインデックスを使用して選択ステートメントを処理...
序文今日は、Prince が Windows で負荷分散に Nginx + Tomcat を使用する...
厳密に言えば、nginx には負荷分散バックエンド ノードのヘルス チェック機能はありませんが、デフ...
目次1. ファイアウォールの現在の状態を確認する2. ファイアウォールサービスを開始する3. ファイ...
背景tomcat によって生成された catalina.out ログ ファイルが分割されていない場合...
成果を達成する 実装コードhtml <div class="wrap"&g...
SVN は Subversion の略称で、ブランチ管理システムを使用して効率的に管理するオープンソ...
序文:前の記事を読んだ後、binlog はデータベースで実行されたすべての DDL および DML ...
1.公式サイトからダウンロードして解凍する参考: 2. 環境変数を設定するMYSQL_HOMEをMy...
<br />読みやすさはウェブサイトにとって非常に重要な部分であり、ウェブサイトの核心と...
導入: Nginx (エンジン エックスと同じ発音) は、BSD のようなプロトコルに基づいてリリー...
1. ソースコードの設計コードをコピーコードは次のとおりです。 <!DOCTYPE html ...
@Font-face 基本紹介: @font-face は、Web ページにカスタム フォントを表示...
1. はじめに数日前、開発仲間から、フィールドを同じ値に更新すると binlog が記録されるかどう...