【MySQL】条件约束

测试智商的网站 1周前 (09-30) 阅读数 1590 #软件测试


阿华代码,不是逆风,就是我疯,希望本文内容能帮到你!你们的点赞收藏是我前进最大的动力!!

目录

前引:为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销

1:not null

【MySQL】条件约束

2:unique

【MySQL】条件约束

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号商品给删除掉,但是子表订单表还必须得保存着,怎么办(在引入外键约束的情况下,如何删除商品表中的数据,但是不影响订单表)

  • 随机文章
  • 热门文章
  • 热评文章
热门