如何在MySQL中设置外键约束以及外键的作用?
外键的作用:外键主要用来保证数据的完整性和一致性,便于关系数据的日常维护。是两张关系表中的主表数据修改或删除是自动操作字表中的数据。(外键并不是费用不可,通过程序逻辑上的操作完全可以替代)
注意事项:
1、两个表必须是InnoDB表,MyISAM表暂时不支持外键
2、如果在较早的版本(4.1.2以前)则需要显示建立外键列必须建立了索引
3、外键关系的两个表的列必须是数据类型相似。比如int和tinyint可以,而int和char则不可以
外键约束使用最多的两种情况:
1)父表更新时子表也更新,父表删除时如果子表有匹配的项,删除失败;
2)父表更新时子表也更新,父表删除时子表匹配的项也删除。
前一种情况,在外键定义中,用ON UPDATE CASCADE ON DELETE RESTRICT;
后一种情况,可以使用ON UPDATE CASCADE ON DELETE CASCADE。
举例说明:用最常见的场景:文章表,和分类表;
创建外键约束:
ALTER TABLE `article`ADD CONSTRAINT `fk_1` FOREIGN KEY (`category_id`) REFERENCES `category` (`id`);
现在删除分类表中的一条数据:
文章表添加一条数据:
这样是不是就保证了文章表里的分类ID 都能在分类表找到对应的名称啦?
下面我们删除外键重新创建:
MySQL几张表中怎么设置主键约束和外键约束并设置级联更新?
MySQL中可以通过以下方式设置主键约束和外键约束,并设置级联更新:1. 设置主键约束:在创建表时,可以使用PRIMARY KEY关键字来设置主键约束。
例如,创建一个名为"students"的表,其中"student_id"字段为主键:CREATE TABLE students ( student_id INT PRIMARY KEY, name VARCHAR(50), age INT);2. 设置外键约束:在创建表时,可以使用FOREIGN KEY关键字来设置外键约束。
例如,创建一个名为"courses"的表,其中"student_id"字段为外键,参考了"students"表的主键:CREATE TABLE courses ( course_id INT, course_name VARCHAR(50), student_id INT, FOREIGN KEY (student_id) REFERENCES students(student_id));3. 设置级联更新:可以使用ON UPDATE CASCADE关键字来设置级联更新。
例如,修改"courses"表的外键约束,使其在"students"表中的主键更新时,自动更新"courses"表中的外键值:ALTER TABLE courses MODIFY student_id INT, FOREIGN KEY (student_id) REFERENCES students(student_id) ON UPDATE CASCADE;通过以上设置,当"students"表中的主键值更新时,"courses"表中对应的外键值也会自动更新。
总结:MySQL中,可以通过使用PRIMARY KEY关键字设置主键约束,使用FOREIGN KEY关键字设置外键约束,并使用ON UPDATE CASCADE关键字设置级联更新。
这样可以保证数据的完整性和一致性。