阿华代码,不是逆风,就是我疯,希望本文内容能帮到你!你们的点赞收藏是我前进最大的动力!!
目录
前引:为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销
前引:为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销
编辑
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号商品给删除掉,但是子表订单表还必须得保存着,怎么办(在引入外键约束的情况下,如何删除商品表中的数据,但是不影响订单表)