约束的作用,是用于保证 数据的完整性或者合理性的工具!
外键 :foreign key,当前表内,指向其他表的主键的字段,称之为外键!
data:image/s3,"s3://crabby-images/5a865/5a8651e745aa27ec2592e1bcd4fabb9205d777f6" alt=""
外键约束:用于限制相关联的记录在逻辑上保证合理性的约束称之为外键约束!
约束,不是字段。
建立班级表
data:image/s3,"s3://crabby-images/380d0/380d030137c9faf10f52f2e6625e3f6aa4778aff" alt=""
再创建学生表
data:image/s3,"s3://crabby-images/0c69a/0c69af6576fb3c448b2abdbccfb174370b8b502c" alt=""
看看删除班级的情况:
data:image/s3,"s3://crabby-images/98b80/98b803dba9a783fd9b8f1a8a72f6da11ade4f5a5" alt=""
出现了不合理数据:
此时,可以通过增加 外键约束 的方式,来限制以上的操作!
增加外键
----
alter table 表名 add constraint 约束的名字 foreign key 外键索引名字 (外键字段名) references 关联表名 (关联字段) [操作]
data:image/s3,"s3://crabby-images/33a9e/33a9efbf7fd108e9b37cd1ad8496fc970fb4eecd" alt=""
再删除个试试:
data:image/s3,"s3://crabby-images/ab881/ab8815dc1c3fb92ae99e6e5425854ecd77c58622" alt=""
注意:如果当前的数据,已经不符合所见约束关联,则创建失败!
删除外键
----
alter table table\_name drop foreign\_key 外键名字!
可以通过 show create table 查看 约束的名字:
data:image/s3,"s3://crabby-images/08bcf/08bcfc500bd28c7399ac895884150448c5bd5a44" alt=""
注意,外键约束与索引的关系:
如果需要在某个字段上,增加外键约束,那么需要该字段也同样有索引!如果该字段上,没有索引,此时,mysql会自动在该字段上增加一个普通索引!
data:image/s3,"s3://crabby-images/0b265/0b2658282a88df3b8c1655fb0649734efbeb27b5" alt=""
可以选择指定外键约束的名字:
data:image/s3,"s3://crabby-images/ba2f9/ba2f9802dd57a8581c5846e84f7575791cb751df" alt=""
data:image/s3,"s3://crabby-images/3afb1/3afb1e83f7c5cd73c9f8a03be7b552862771a036" alt=""
注意上面的 外键约束自动建立的索引的名字,与 外键的名字相同!
总结:在创建时:
1, 外键 与 相应关联表的主键类型
2, 已有数据,必须满足约束条件才可以!
3, 可以使用 constraint 关键字,为外键约束起名字!
约束操作
----
在 对 父表(被关联的表)做操作时,有三种行为:
1, 严格限制,拒绝操作。restrict
2, 置 null,set null
3, 级联操作,cascade
以上三个行为操作,会在 主表记录被 删除 或者 更新时被使用!
on delete set null
on update cascade
data:image/s3,"s3://crabby-images/45659/45659f3bf39ed45b2d71646d42c874cc2d0ff1f3" alt=""
data:image/s3,"s3://crabby-images/66f4d/66f4df2982d57d23de685b5b0c91a4d0a65db9a9" alt=""
更新时的级联操作:
只有在 关联表的主键发生变化时,才会影响到从表的关联字段的变化!
data:image/s3,"s3://crabby-images/f7b8f/f7b8f1494e7f3e9312fa7f21c39b1cede5e22df1" alt=""
主表:被关联的
从表:发出关联的!
应该注意的问题:
关于,外键约束,只能在 当前的 mysql的的 innodb 表类型(引擎)下才会生效!
data:image/s3,"s3://crabby-images/5a153/5a1531f9fc6de079ae104ad546537b20629d77c1" alt=""
外键,站在 php程序的角度,用到的不多!
数据操作,DML,DATA Management Language