Mysql学习历程(13)-外键

外键 foreign key  如果一张表中有一个字段,非主键指向另一张表的主键,那么将该字段称为外键

增加外键:在创建表的时候或者创建表之后增加(但要考虑数据的问题);

创建表的时候增加外键,在所有表字段之后,使用foreign key (外键字段) references  外部表(主键字段);

create table my_foreign(
id int primary key auto_increment,
name varchar(20) not null comment '学生姓名',
c_id  int comment '班级id',
foreign key (c_id) references my_class (id)
)charset utf8 engine innodb;
注意:外键要求字段本身必须先是一个索引(普通索引),如果字段本身没有索引,外键会先创建一个索引,然后才会创建外键本身.


新增的表创建之后增加外键,修改表结构:

alter table 表名  add constraint  外键名字  foreign key (外键字段) references 父表(主键字段);

alter table my_student_1  add  constraint 
my_student_1_cid   foreign key (c_id)
references  my_class(id);


外键修改必须先删除后新增;删除外键,  alter table drop foreign key 外键名 ;  --  一张表可以有多个外键,但是外键名不能相同;

外键删除后不能通过查看表结构体现,应该通过查看表创建语句查看;


外键作用:1.对子表约束,子表进行写操作的时候,如果对应外键字段在父表中找不到对应的匹配,那么操作会失败;

2.对父表约束,父表进行写操作(删和改,数据都涉及到主键本身),如果对应主键在子表中已经被数据所引用,那么不允许操作;

外键条件:1.必须保证存储引擎为innodb 默认的存储引擎,;如果不是innodb,那么外键可以创建成功,但是没有约束效果

2.外键字段的字段类型(列类型)必须与父表的主键类型完全一致;

3.一张表中外键名字不能重复;

4.增加外键的字段(数据已经存在),必须保证数据与父表主键要求对应;


外键约束:外键的作用,其实可以通过对外键的需求,进行定制操作;

外键约束有三种约束模式,都是针对父表的约束

1.distinct:严格模式,默认的,父表不能删除或更新一个已经被子表数据引用的记录;

2.cascade:级联模式,父表的操作,对应子表关联数据也跟着操作

3.set null:置空模式,父表的操作之,子表中对应的数据(外键字段)被置空;

合理的约束模式:删除的时候子表置空,更新的时候子表级联操作;

指定模式语法:foreign key (外键字段) references  父表 (主键字段)  on delete 模式 on update 模式

删除置空的前提:外键字段允许为空(如果不满足条件,外键无法创建);



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值