了解 MySQL 中外键的基础知识?
短信预约 -IT技能 免费直播动态提醒
外键可用于创建表之间的关系。外键关系可以是一对一或一对多。外键与另一个表的另一个字段匹配。
一对一关系 - 一个表中的一条记录将链接到另一个表中的一条记录。
一对多关系 - 一条记录将链接到另一个表中的多条记录。
下面是一个例子。首先,我们将创建一个表。 CREATE命令用于创建表。
mysql> create table tblF
- > (
- > id int ,
- > FirstName varchar(100),
- > FK_PK int
- > );
Query OK, 0 rows affected (0.57 sec)
创建第二个表。
mysql> create table tblP
- > (
- > FK_PK int,
- > LastName varchar(100),
- > primary key(FK_PK)
- > );
Query OK, 0 rows affected (0.94 sec)
以下是创建外键的语法。
mysql> ALTER table tblF add constraint ConstFK foreign key(FK_PK) references tblP(FK_PK);
Query OK, 0 rows affected (2.17 sec)
Records: 0 Duplicates: 0 Warnings: 0
使用DESC命令检查外键是否已经创建。
mysql> DESC tblF;
以下是输出。
+-----------+--------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------+--------------+------+-----+---------+-------+
| id | int(11) | YES | | NULL | |
| FirstName | varchar(100) | YES | | NULL | |
| FK_PK | int(11) | YES | MUL | NULL | |
+-----------+--------------+------+-----+---------+-------+
3 rows in set (0.05 sec)
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341