在 mysql 中通过外键设置数据完整性,确保父子表引用关系。创建父表后,创建子表并添加外键列,该列引用父表中的主键。优势包括数据完整性、级联删除/更新操作和查询优化。
如何设置 MySQL 外键
在 MySQL 中设置外键可以确保数据完整性,它强制执行父子表之间的引用关系。
语法
ALTER TABLE 子表 ADD FOREIGN KEY (子表列) REFERENCES 父表 (父表列)
步骤
-
创建父表
首先,创建包含父数据的父表:
CREATE TABLE 父表 ( id INT NOT NULL AUTO_INCREMENT, name VARCHAR(255) NOT NULL, PRIMARY KEY (id) );
-
创建子表
接下来,创建包含子数据的子表,并添加外键列:
CREATE TABLE 子表 ( id INT NOT NULL AUTO_INCREMENT, name VARCHAR(255) NOT NULL, 父表_id INT NOT NULL, FOREIGN KEY (父表_id) REFERENCES 父表 (id), PRIMARY KEY (id) );
-
插入数据
插入数据时,确保子表的 父表_id 列值引用父表中的现有记录:
INSERT INTO 父表 (name) VALUES ('父表记录 1'); INSERT INTO 子表 (name, 父表_id) VALUES ('子表记录 1', 1);
优势
设置外键有以下优势:
- 数据完整性:确保子表中的数据与父表中的数据一致。
- 级联操作:当父表记录被删除或更新时,级联操作允许自动更新或删除子表中的相关记录。
- 查询优化:通过使用外键索引,可以优化涉及子表和父表联接的查询。
提示
- 父表中的列类型应与子表中的外键列类型匹配。
- 父表中的列应具有唯一约束或主键。
- 外键列在子表中通常非空。
以上就是mysql设置外键怎么写的详细内容,更多请关注php中文网其它相关文章!
版权声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系 yyfuon@163.com