mysql约束

约束是MySQL中确保数据正确性的规则,包括非空、唯一、主键和外键约束。外键约束用于维护表格间的数据一致性,涉及删除/更新行为如NOTACTION、RESTRICT、CASCADE、SETNULL。添加和删除外键使用ALTERTABLE语句,配合ONUPDATE和ONDELETE指定约束行为。
摘要由CSDN通过智能技术生成

概念

约束是作用于表中字段上的规则,用于限制存储在表中的数据。

目的

保证数据库中数据的正确、有效性和完整性。

分类

约束描述关键字
非空约束限制字段的数据不能为nullNOT NULL ( not null )
唯一约束保证该字段的所有数据都是唯一、不重复的UNIQUE ( unique )
主键约束主键是一行数据的唯一标识,要求字段非空且唯一 。(自增 AUTO_INCREMENT)PRIMARY KEY ( primary key )
默认约束保存数据时,如果未指定该字段的值,则采用默认值DEFAULT ( default )
检查约束(8.0.16 版本之后)保证字段满足某一个条件CHECK ( check )
外键约束用来让两张表数据之间建立连接,保证数据的一致性和完整性FOREIGN KEY ( foreign key )

外键约束

删除/更新行为

行为说明
NOT ACTION ( not action )当在父表中删除/更新关联列时,首先检查该记录是否有对应的外键,如果有则不允许删除/更新。(与 RESTRICT 一致)
RESTRICT ( restrict )当在父表中删除/更新关联列时,首先检查该记录是否有对应的外键,如果有则不允许删除/更新。(与 NOT ACTION 一致)
CASCADE ( cascade )当在父表中删除/更新关联列时,首先检查该记录是否有对应的外键,如果有,则也删除/更新外键在 子表中的记录
SET NULL ( set null )当在父表中删除/更新关联列时,首先检查该记录是否有对应的外键,如果有则设置子表中该外键值为null 。( 这里要外键允许为null)
SET DEFAULT ( set default )父表有变更时,子表将外键列设置成一个默认的值( inoodb 不支持)

添加外键 (无外键约束)

ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名) REFENCES 父表名(关联列名)

添加外键(有外键约束)

ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名) REFENCES 父表名(关联列名)ON UPADATE 外键约束 ON DELETE 外键约束

删除外键

ALTER TABLE 表名 DROP FOREIGN KEY 外键名称
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值