MySQL(条件约束)

阿华代码解读,不是逆风就是你疯QLQ 

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

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

  • 24
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值