数据表的约束

目录

 数据表的约束

主键约束(primary key)

创建表时添加主键约束

为已存在的表添加主键约束

删除主键约束

复合主键 [primary key(_,_)]

创建表时添加复合主键

为已存在的表添加复合主键

删除复合主键

外键约束(foreign key)

创建表时添加外键约束

为已存在的表添加外键约束 

 删除外键约束

非空约束(not null) 

创建表时添加非空约束

为已存在的表添加非空约束 

删除非空约束 

唯一约束(unique) 

创建表时添加唯一约束

为已存在的表添加唯一约束 

删除唯一约束

默认约束(default) 

创建表时添加默认约束

为已存在的表添加默认约束 

删除默认约束

​编辑

 总结

 数据表的约束

主键约束(primary key)

创建表时添加主键约束

为已存在的表添加主键约束

alter table 表名 modify 字段名 字段类型 primary key;

删除主键约束

alter table 表名 drop primary key;

复合主键 [primary key(_,_)]

创建表时添加复合主键

为已存在的表添加复合主键

alter table 表名 add  primar key(字段名1,...,字段名n);

删除复合主键

alter table 表名 drop primary key;

外键约束(foreign key)

创建表时添加外键约束

constraint fk_从表名_主表名 foreign key(主表的主键) references 主表名(主键名);

解析: 

外键约束是添加一个外键(也就是另一个表的主键),所以想创建外键至少要两个表,我之前创建了学生表(studentinfo)主键是sno,所以我又创建了一个选课表(elective)在创建的时候添加了外键,利用show create table 表名就能查看外键。

为已存在的表添加外键约束 

alter table 表名 add constraint fk_从表名_主表名 foreign key(主表的主键) references 主表名(主键名);

  • 从表是对于两个具有相连关系的表而言,外键所在的表即为从表
  • 主表是对于两个具有相连关系的表而言,主键所在的表即为主表

 删除外键约束

alter table 表名 drop foreign key fk_表名_表名

解析: 在删除了外键约束的时候查询还是会出现索引“key fk_ _”的样式,是因为MYSQL在创建外键后,会自动创建一个同名的索引,外键删除,但是索引不会被删除。

可以用show create table 表名查看外键约束是否删除。

非空约束(not null) 

创建表时添加非空约束

为已存在的表添加非空约束 

alter table 表名 modify 字段名 字段类型 not null;

删除非空约束 

alter table 表名 modify 字段名 字段类型;

 唯一约束(unique) 

创建表时添加唯一约束

为已存在的表添加唯一约束 

alter table 表名 modify 字段名 字段类型 unique;

删除唯一约束

alter table 表名 drop index 字段名;

默认约束(default) 

创建表时添加默认约束

为已存在的表添加默认约束 

alter table 表名 modify 字段名 字段类型 default "";

删除默认约束

alter table 表名 modify 字段名 字段类型;

 总结

  • 在创建表时添加约束在字段类型后面补充即可,但是中间记得用空格隔开,每个字段的设置结束一般以“,”结束。
  • 在为已存在的表添加约束的时候,只有添加复合主键和添加外键约束的时候用的是add,添加其他约束的时候用的都是modify
  • 删除约束的时候,只有删除非空约束和默认约束的时候用的是modify,删除其他约束的时候用的都是drop

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值