MYSQL一一外键约束
2023-12-28 17:38:08
概念:外键用来让两张表的数据之间建立联系,从而保证数据的一致性和完整性
建立外键:
①这是在建立表的时候建立外键的方法
②这是在建立完表之后建立外键的方法:
删除外键:
现在有一张员工表(emp)和一张部门表(dept)?
①员工表中有一个名为dept_id的字段,它是这个表的外键,与dept表关联;
②员工表又称子表/从表,部门表又称父表/主表;(我们把有外键的这张表成为子表,而被外键所关联的表成为父表);
列题:
首先创建dept表:
创建emp表:
给emp表建立外键:
alter table emp add constraint fk_dept_id foreign key (dept_id) references dept(id);
//这是设置的外键的名称,大家可以随便设。
//这是子表(emp)中的与dept表建立关系的字段
//这是父表(dept)的id字段
建立成功后如何验证呢?因为两个表建立了联系,所以如果你要把主表dept的内容删除时删不掉的
看下图:咱们运行的语句时删除字段id为1的那一行,是删不掉的
删除外键:
ALTER TABLE emp DROP FOREIGN KEY fk_dept_id;
//这是咱建立外键的时候设置的外键名
?
删除成功后如何验证呢?删除了外键咱就和dept表没有了联系,那咱们想删除dept表中的内容就可以删掉。
下图是删除成功的截图
文章来源:https://blog.csdn.net/m0_74197121/article/details/135272798
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!