专业网站建设品牌,十四年专业建站经验,服务6000+客户--广州京杭网络
免费热线:400-683-0016      微信咨询  |  联系我们

mysql 查询树父节点,如何在MySQL中设置外键约束以及外键的作用_数据库

当前位置:网站建设 > 技术支持
资料来源:网络整理       时间:2023/3/5 13:29:47       共计:3586 浏览
mysql 查询树父节点,如何在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是如何利用索引的_数据库 | ·下一条:mysql多字段模糊查询,Java难学么_数据库

Copyright © 广州京杭网络科技有限公司 2005-2024 版权所有    粤ICP备16019765号 

广州京杭网络科技有限公司 版权所有