ホームページ >データベース >mysql チュートリアル >テーブルの外部キー制約を作成する SQL ステートメントは何ですか?
SQL 外部キー制約は FOREIGN KEY キーワードで指定でき、作成ステートメントは「ALTER TABLE テーブル名 ADD CONSTRAINT 外部キー名 FOREIGN KEY (列名) REFERENCES メインテーブル名 (列名);」 となります。 。
このチュートリアルの動作環境: Windows7 システム、mysql8 バージョン、Dell G3 コンピューター。
MySQL 外部キー制約 (FOREIGN KEY) はテーブルの特別なフィールドであり、主キー制約と一緒によく使用されます。関連付けられた 2 つのテーブルの場合、関連付けられたフィールドの主キーが配置されているテーブルが主テーブル (親テーブル) となり、外部キーが配置されているテーブルが副テーブル (子テーブル) になります。
外部キーは、マスター テーブルとスレーブ テーブル間の関連付けを確立し、2 つのテーブルのデータの接続を確立し、2 つのテーブルのデータの一貫性と整合性を制約するために使用されます。
テーブルの外部キー制約の作成
ALTER TABLE ステートメントの FOREIGN KEY キーワードを使用して外部キーを指定でき、外部キー制約を追加します。前提条件は、セカンダリ テーブルの外部キー カラムのデータがプライマリ テーブルの主キー カラムのデータと一致している必要があり、そうでない場合はデータがありません。
具体的な構文形式は次のとおりです。
ALTER TABLE <数据表名> ADD CONSTRAINT <外键名> FOREIGN KEY(<列名>) REFERENCES <主表名> (<列名>);
外部キーを定義する場合は、次の規則に従う必要があります
例:
mysql> ALTER TABLE tb_emp2 -> ADD CONSTRAINT fk_tb_dept1 -> FOREIGN KEY(deptId) -> REFERENCES tb_dept1(id); Query OK, 0 rows affected (1.38 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> SHOW CREATE TABLE tb_emp2\G *************************** 1. row *************************** Table: tb_emp2 Create Table: CREATE TABLE `tb_emp2` ( `id` int(11) NOT NULL, `name` varchar(30) DEFAULT NULL, `deptId` int(11) DEFAULT NULL, `salary` float DEFAULT NULL, PRIMARY KEY (`id`), KEY `fk_tb_dept1` (`deptId`), CONSTRAINT `fk_tb_dept1` FOREIGN KEY (`deptId`) REFERENCES `tb_dept1` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=gb2312 1 row in set (0.12 sec)注: 作成したデータ テーブルに外部キー制約を追加するときは、外部キー制約が追加される列の値がすべて主キー列からのものであることを確認してください。列を空にすることはできません。 (推奨チュートリアル:
mysql ビデオ チュートリアル )
以上がテーブルの外部キー制約を作成する SQL ステートメントは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。