【MySQL】条件约束

举报
三三是该溜子 发表于 2025/05/05 10:31:54 2025/05/05
44 0 0
【摘要】 ​阿华代码,不是逆风,就是我疯,希望本文内容能帮到你!你们的点赞收藏是我前进最大的动力!!目录前引:为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销1:not null2:unique3:default4:primary key5:自增主键auto_increment6:foreign key(外键约束)前引:为了校验数据,让数据的正确性能够...


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

目录

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

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

【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

作者其他文章

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

    全部回复

    上滑加载中

    设置昵称

    在此一键设置昵称,即可参与社区互动!

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。