mysql外键约束怎么写
1 外键约束的写法是在创建表时使用FOREIGN KEY关键字来指定外键约束。
2 外键约束的原因是为了保证数据的完整性和一致性。
通过外键约束,可以限制一个表中的某个列的值必须在另一个表的指定列中存在,从而确保数据的关联性和正确性。
3 外键约束的是可以通过外键约束来实现表与表之间的关联和连接,从而方便进行数据查询和操作。
外键约束还可以用于实现级联操作,例如当删除或更新主表中的数据时,可以自动删除或更新相关联的从表中的数据,避免数据不一致的问题。
因此,使用外键约束可以提高数据库的数据质量和操作效率。
MySQL外键约束可以通过在创建表或修改表时添加FOREIGN KEY关键字来实现。语法为: FOREIGN KEY (列名) REFERENCES 目标表(列名) ON DELETE CASCADE/SET NULL/RESTRICT。其中,列名为当前表中的列名,目标表为引用的外部表名,ON DELETE CASCADE/SET NULL/RESTRICT表示当删除外部表中的记录时,当前表中的记录应该如何处理。CASCADE表示级联删除,SET NULL表示将当前表中相关记录的外键值设为NULL,RESTRICT表示禁止删除。
如何在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 都能在分类表找到对应的名称啦?
下面我们删除外键重新创建: