【MySQL】条件约束
阿华代码,不是逆风,就是我疯,希望本文内容能帮到你!你们的点赞收藏是我前进最大的动力!!
目录
前引:为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销
1:not null
2:unique
3:default
4:primary key
5:自增主键auto_increment
6:foreign key(外键约束)
前引:为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销
1:not null
指示某列不能存储null
应用①create table student(id int not null , name varchar(20));
2:unique
保证某列的每一行必须有唯一的值,后续再插入数据的时候,都会先进行查询表里是否已经存在这个数据了
应用:create table student(id int unique , name varchar(20));
如果表里已经有(1,‘张三’)这个数据了,在插入重复的数据就会报错,
3:default
规定没有给列赋值时的默认值,默认情况下就是null,进行指定列插入时,未被指定到的列会被设置成默认值null,默认值可以自己设定(用户体验++)
应用:create table student(id int default 0 , name varchar(20) default ‘无名氏’);
4:primary key
①可以理解成not null 和 unique 的结合(非空&唯一) ,确保某个列(或者多个列的结合)有唯一的标识,有助于更容易更快速的找到表中一个特定的主键,用来作为一个记录的身份标识。
②一个表里只能有一个主键
5:自增主键auto_increment
(在primary key 的基础上)
create table student(id int primary key auto_increment ,name varchar(20));
当前id不需要自己去指定(也可以自己指定),数据库会按照自增的方式(自增数据必须是整形)来分配
每次使用null的方式插入数据时,都会在这一列最大值的基础上继续往后增加,这里递增是不会重复利用之前的值的
这里插入了100,101后,再想在(4,100)这个区间自增插入id数值就不可以了
注:①unique可以为空,但是主键不能为空
②如果数据库是由多个mysql服务器构成的“集群”,此时自增主键就无法生效了
6:foreign key(外键约束)
(保证一个表中的数据匹配另一个表中的数据的参照完整性)
所以引入外键约束(被约束的表<学生表>叫“子表”,约束别人的表<班级表>叫“父表”)
“父亲约束儿子”
create table student (id int , name varchar(20) , classId int , foreign key(classId) references class(classId));
注:前面几个约束关键字,都是哪一列需要约束,就在该列的后面加上约束条件,而foreign key是在列定义完成之后,加在最后最后面。
约束是相互的:在删除“父表”中的数据的时候,如果子表中有数据受该父表此数据的约束的话,是删不掉的,要确保子表中没有数据引用父表的记录,才能删除父表上的该数据
关于外键约束还有一个应用场景
应用场景:现在订单表中把商品1给买走了,那么商品表中要把1号商品给删除掉,但是子表订单表还必须得保存着,怎么办(在引入外键约束的情况下,如何删除商品表中的数据,但是不影响订单表)
- 随机文章
- 热门文章
- 热评文章
- 心理测试性格探索自我:深入了解你的性格特点性格类型测试免费
- 揭秘人际关系的秘密:心理测试与实用策略人际关系心理测试题及答案
- 生辰八字与名字打分:探索姓名学与命理学的交汇点
- 科学与迷信:揭秘100%准确测试男孩女孩的真相100%准确测试男孩女孩2024年
- 机器学习如何让运维成本更“抠门”?——数据驱动的降本增效指南
- 利用DevEco Profiler定位性能瓶颈,优化资源占用
- Java 邮件发送系统
- 测你情绪易怒性有多少
- Java 企业级应用:SOA 与微服务的对比与选择