【MySQL数据库】:MySQL表的约束

目录

一、空属性

 二、默认值

三、列描述 

四、zerofill

五、主键

复合主键 

六、自增长 

七、唯一键

八、外键

九、综合案例


我们查看表的结构发现上面还有Null 和 Key等等的字样!!!

这些就是表的约束!!!

  • 约束的作用:表中一定要有各种的约束,通过约束,让我们未来插入数据库中的数据是符合预期的!!
  • 约束本质:倒逼程序员插入正确的数据!!
  •  约束的最终目的:确保数据的完整性和一致性!!

一、空属性

基本语法:

需要的字段后加上 not null
  • 空属性有两个值,分别是null和not null。
  • 数据库默认字段基本都是允许为空的,但在实际开发中我们要尽可能保证字段不为空,因为空值无法参与运算

例子:我们日常生活中在填写一些问卷的时候,有些选项是必选的,比如名字选项后面就常常带着一个*号,如果你不填写就把问卷提交那么是提交不成功的。这就是非空约束!!!

真实案例

创建一个班级表,包含班级名和班级所在的教室。
站在正常的业务逻辑中:
  • 如果班级没有名字,你不知道你在哪个班级
  • 如果教室名字可以为空,就不知道在哪上课
所以我们在设计数据库表的时候,一定要在表中进行限制,满足上面条件的数据就不能插入到表中。这就是“非空 约束
创建一个表test1,有两个字段,并且都是非空约束!!!

 向表中插入记录时只有这两个字段都不为空时才能插入成功,否则将会插入失败。

 二、默认值

基本语法:
 

需要的字段后加上 default value(需要设立的默认值)
  • 如果某一个字段会经常性的出现某个值,那么就可以考虑将这个值设置成该字段的默认值。
  • 向表中插入数据时如果不给带有默认值的字段赋值,那么就会使用默认值进行插入。

例子:我们日常生活中在填写一些问卷的时候,有些选项是默认的,比如民族选项后面就常常默认是汉族,如果你不是汉族就修改就可以了。这就是默认值!!!

创建一个表test2,有三个字段,并且将age字段的默认值设置为0。

  向表中插入记录时我们如果不给age字段赋值的话,age字段就会使用默认值0。

 向表中插入记录时我们如果不给gender字段赋值的话,gender字段会是NULL。

我们会很疑惑我们没有给gender字段添加默认值啊,为啥gender字段不赋值就会默认为NULL呢?原来我们在创建表的时候mysql并不会直接用你的创建,而是会优化后再创建!!!

同时设置not null和default 

  • 一旦给某一字段设置了默认值,那么该字段将不会出现空值,因为就算插入数据时没有指明该字段的值,也会使用该字段的默认值进行填充。
  • 而给某一字段设置not null属性的目的是约束该字段不能为空,因此一个字段设置了default属性后,再设置not null属性就没有意义了。

比如创建一个id表,表当中包括姓名和id,将id同时设置default和not null属性。

此时在向表中插入数据时可以不指明id进行插入,此时会使用id的默认值。

三、列描述 

基本语法:

需要的字段后加上 comment "(描述的信息)"

列描述是在创建表的时候用来对各个字段进行描述的,列描述会根据表创建语句保存,一般是用来给程序员或DBA了解表的相关信息的,相当于一种注释。

比如创建一个用户表,表当中包含用户名、用户的年龄和用户的性别,在每一个字段后面添加上对应的列描述。

 创建表完毕后,通过show create table 表名SQL可以看到创建表时的相关细节,包括列描述。

四、zerofill

基本语法:

需要的字段后加上 zerofill

数值类型后面的圆括号中的数字,代表的是显示宽度,对应数值类型设置zerofill属性后,如果数据的宽度小于设定的宽度则自动填充0。

创建一个表,表当中包含a和b两列整型数据,将它们的显示宽度都设置成5!!!

向表中插入一条记录,赋值a和b的值均为1!!!

如果修改表结构,给a列添加上zerofill属性, 由于a列数据的显示宽度为5,因此查看表中数据可以看到a列数据中宽度不足5位的数据都自动在前面填充0了。

需要注意的是,zerofill属性的作用就是让数据以特定的方式进行显示而已,数据底层的储存方式并没有发生变化,通过hex函数可以看到a列中显示的00001在底层实际储存的还是1。

五、主键

基本语法:

1、需要的字段后加上 primary key
2、primary key(一个或多个字段)
  • 我们向表当中插入一条条记录后,为了方便后续进行查找,我们可以选择其中的某一字段作为键值key,当需要查找记录时就根据这个键值key来查找对应的记录。
  • 主键用来唯一的约束该字段里面的数据,表当中每条记录的主键不能重复也不能为空,并且一张表里面只能有一个主键,此外,主键所在的列通常是整数类型。 

 比如创建一个学生表,表当中包含学生的学号和姓名,由于学生的学号是不会重复的,因此可以将其设置成主键。

创建表成功后查看表结构,可以看到id对应的Key列出现了PRI,这表示我们已经成功将学号设置成这张表的主键了。此外,虽然在创建表的时候没有给学号设置not null属性,但由于主键本身就是不能为空的,因此id默认也就不能为空了

所谓的主键约束就是,插入表中的记录的主键字段不能重复,如果插入记录的主键与表中已有记录的主键重复,这时就会因为主键冲突而插入失败。 

 使用alter table 表名 drop primary keySQL即可删除指定表的主键,因为一个表只有一个主键,因此删除主键时只用指明要删除哪张表的主键即可。比如这里删除学生表的主键后再查看表结构,可以看到id对应的Key列的PRI已经没有了。

对于已经创建好了的表,使用alter table 表名 add primary key(列名)SQL可以给指定列设置成主键,但是需要注意的是,只有列当中的值不为空并且不重复的列才能被设置成主键。比如这里重新将学号设置成学生表的主键后再查看表结构,可以看到id对应的Key列的PRI又回来了。

 

复合主键 

  • 一张表里面只能有一个主键,但一个主键可以由多个字段来承担,这种主键叫做复合主键。
  • 复合主键用来唯一约束多个字段里面的数据,表当中每条记录的这多个字段不能同时重复也不能为空。

创建一个表test5,

在向进程表中插入数据时,只有插入id和course均出现冲突时才会产生主键冲突,否则就允许插入。 

查看表中插入的数据可以看到,表当中有重复的IP地址,也有重复的端口号,但是不会出现IP和端口均重复的,这就是复合主键的作用。 

使用alter table 表名 drop primary keySQL可以删除指定表的复合主键,比如这里删除进程表的复合主键后再查看表结构,可以看到ip和port对应的Key列的PRI都没有了。 

对于已经创建好了的表,也可以使用alter table 表名 add primary key(多个列名)SQL用多个列形成复合主键,但是需要注意的是,被选取的多个列当中的值不能为空并且不能同时出现重复

六、自增长 

基本语法:

需要的字段后加上 auto_increment
注意:必须和主键一起使用!!!
auto_increment :当对应的字段,不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值+1操作,得到一个新的不同的值。通常和主键搭配使用,作为逻辑主键。
自增长的特点
  • 任何一个字段要做自增长,前提是本身是一个索引(key一栏有值)
  • 自增长字段必须是整数
  • 一张表最多只能有一个自增长

创建一个表test6,表当中包含id和name字段,将id字段同时设置成主键和自增长字段。 可以看到id的Extra列中出现了auto_increment标志。

 向表中插入第一条记录时如果没有指明自增长字段的值,那么自增长字段的值默认将会从1开始。

插入记录的时候也可以指明自增长字段的值,此时将会使用该值进行插入,但注意指明的值不能和表中已有的id值重复。 

此后向表中插入记录时如果又不指明自增长字段的值,那么自增长字段的值将会从id列中找出最大值,将最大值加一后得到的值作为自增长字段的值进行插入。 

建议:一般自增长字段设置后就不需要手动为该字段插入值了,直接让其从1开始进行自增长即可。 

七、唯一键

基本语法:

需要的字段后加上 unique
一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多个字段需要唯一性约束的问题。
唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较。
关于唯一键和主键的区别:

主键(Primary Key)

  • 用于唯一标识表中的每一行记录。
  • 不能为空值。
  • 一张表只能有一个主键。
  • 主键通常用于建立表与其他表之间的关系。

唯一键(Unique Key)

  • 也确保列或列组合的值是唯一的,但可以有空值。
  • 一张表可以有多个唯一键。

 例子:比如,在员工表中,我们可以使用工号来作为主键,但是电子邮件地址也必须是唯一的,可以有一个唯一键来保证员工的电子邮件地址唯一,可能某些员工没有提供电子邮件,即存在空值。

创建一个学生表,表当中包含学生的id、姓名和电话号码字段,将我们选择id字段作为主键,但同时每个学生的电话号码字段也应该具有唯一性约束,因此应该将电话号码设置成唯一键。

 向表中插入记录时,如果插入记录中的电话号码与表中已有记录的电话号码出现重复,那么就会因为唯一键冲突而插入失败。

此外,向表中插入的记录可以不指明唯一键字段的值,此时该字段默认为空,不做唯一性比较。 

八、外键

基本语法:

foreign key (字段名) references 主表(列)
  • 外键用来定义主表和从表之间的关系,外键约束主要定义在从表上主表必须有主键约束或唯一键约束。
  • 外键定义后,要求插入外键列的数据必须在主表对应的列存在或为null。

先创建一个班级表作为主表,表当中包含班级的id和班级名字段,并将班级id字段设置为主键。 

再创建一个学生表作为从表,表当中包含学生的id、姓名以及学生所在班级对应的id字段,并将学生表中的班级id字段设置成外键,关联到班级表中的班级id列。 

为了演示外键约束,我们先向班级表中插入两条记录。

 这时向学生表中插入记录时,如果插入的记录对应的班级id是班级表中存在的,或者插入的班级id为null,那么此时是允许进行插入的。

但如果插入学生表的记录对应的班级id是3,相当于插入学生表的这条记录对应的班级并不存在,此时将会插入失败,这就是外键约束。

  • 理论上来说,我们创建班级表和学生表后就算不设置外键,在语义上其实也已经有了外键,但这样我们没办法保证后续插入学生表的记录中的班级id的正确性。
  • 而我们给学生表中的班级id设置成外键后,外键约束就能保证只有班级id在班级表中存在的记录才能插入学生表,否则就会插入失败。
  • 实际建立外键的本质就是把相关性交给MySQL去审核了,提前告诉MySQL表之间的约束关系,当用户插入不符合业务逻辑的数据时,MySQL就不允许你进行插入。

九、综合案例

有一个商店的数据,记录客户及购物情况,有以下三个表组成:
  • 商品goods(商品编号goods_id,商品名goods_name, 单价unitprice, 商品类别category, 供应商
  • provider)
  • 客户customer(客户号customer_id,姓名name,住址address,邮箱email,性别sex,身份证card_id)
  • 购买purchase(购买订单号order_id,客户号customer_id,商品号goods_id,购买数量nums)
要求:
  1. 每个表设置主键和外键
  2. 客户的姓名不能为空值
  3. 邮箱不能重复
  4. 客户的性别(男,女)

首先我们需要先创建一个数据库!!!并且使用

创建商品表的时候,将商品编号设置成主键并且可以将其设置成自增长字段,其他字段的属性没有要求可以自行合理设置。

 创建客户表!!!

 创建购买表!!!

  • 24
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

-元清-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值