MySQL六种约束的示例详解
什么是约束
作用于表上的规则,限制存储在表中的数据
约束分类:
约束 | 描述 | 关键字 |
---|---|---|
非空约束 | 该字段数据不能为null | NOT NULL |
唯一约束 | 该字段数据唯一不重复 | UNIQUE |
主键约束 | 一行数据的唯一标识(非空且唯一) | PRIMARY KEY |
默认约束 | 未指定该字段值则使用默认值 | DEFAULT |
检查约束(8.0.16以后) | 该字段值满足某一条件 | CHECK |
外键约束 | 为两张表建立连接(数据一致、完整) | FOREIGN KEY |
创建表示例:
?1 2 3 4 5 6 7 | CREATE TABLE info( `id` INT UNIQUE auto_increment PRIMARY KEY COMMENT 'ID唯一标识' , ` name ` VARCHAR (10) NOT NULL UNIQUE COMMENT '姓名' , `age` INT CHECK (age > 0 && age < 120) COMMENT '年龄' , `status` CHAR (1) DEFAULT '1' COMMENT '状态' , `gender` CHAR (1) COMMENT '性别' )COMMENT '用户信息表' ; |
外键约束
外键通常用来为两张表建立连接,两张利用外键连接的表被称为父子表。
子表当中会设定一个外键字段用于关联父表的主键字段
即拥有外键的表是子表(从表),该外键对应另一个表的主键这个表称之为父表
如果没有设置外键,仅仅是将子表开了一个字段对应上了父表的主键字段在mysql层面是依旧没有任何关系的。此时两个表仅存在逻辑关系,无法保证数据的完整性和一致性
创建外键语法:
?1 2 3 4 5 6 7 8 9 | -- 在创建表时创建 CREATE TABLE son( ... CONSTRAINT [外键名称] FOREIGN KEY (外键字段名) REFERENCES 主表名(主表主键字段名) ); -- 创建表后为表添加主键 ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名) REFERENCES 主表(主表主键字段名) -- 删除外键 alter table 表名 drop foreign key 外键名称; |
创建示例:
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | # 父表 CREATE TABLE father( `id` INT auto_increment PRIMARY KEY COMMENT '父表ID' , ` name ` VARCHAR (20) NOT NULL COMMENT '姓名' , ` password ` VARCHAR (20) DEFAULT (0000) ); INSERT INTO father VALUES ( null , '小三' , '1234' ),( null , '小四' , '1234' ),( null , '小五' , '1234' ),( null , '小六' , '1234' ); # 子表 CREATE TABLE son( `id` INT auto_increment PRIMARY KEY COMMENT '子表ID' , `status` varchar (10) COMMENT '状态' , `fa_id` INT COMMENT '外键' , CONSTRAINT fk_father_son FOREIGN KEY (fa_id) REFERENCES father(id) ); INSERT INTO son VALUES ( null , '活' ,2),( null , '活' ,3),( null , '死' ,3),( null , '活' ,2); |
上述示例 子表设置了外键,字段名为fa_id并关联到了父表主键id,外键名称为fk_father_son
创建完成后,我们添加几组数据。将几个son添加到表中,并设置外键字段属性为某个father。比如(null,‘活’,3),那么此时如果我们尝试去删除父表id=3的这一行数据,就会提示错误。因为两个表已经在mysql层面上进行了关联
总结:
- 从表的外键通常是主表的主键
- 从表中外键的类型必须与主表中的主键类型一致
- 主表数据发生变化时应注意从表数据的一致性问题
到此这篇关于MySQL六种约束的示例详解的文章就介绍到这了,更多相关MySQL六种约束内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/yuqu1028/article/details/128875020
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。