MySQL —— 表的约束

目录

表的约束 

1. 空属性

2. 默认值

3. 列描述

4. zerofill

5. 主键

6. 自增长

7. 唯一键

8. 外键

9. 综合案例


表的约束 

        真正约束字段的是 数据类型 ,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性。比如有一个字段是email,要求是唯一的。(你的email一定是唯一的,不可能有重复)
表的约束很多,这里主要介绍如下几个:
null/not null default , comment , zerofill primary key auto_increment unique key  

1. 空属性

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

通过select可以看到null的值为null,由于空值无法参与运算,因此null值加一后得到的还是null。

        如果要让某个字段不允许为空,在创建表的时候就可以给对应字段设置not null属性。比如我们创建一个班级表,表当中包含班级名和该班级所在的教室,如果插入数据时不想让这两个字段为空,就可以在创建表时给这两个字段设置not null属性。

站在正常的业务逻辑中:

  • 如果班级没有名字,你不知道你在哪个班级
  • 如果教室名字可以为空,就不知道在哪上课

所以我们在设计数据库表的时候,一定要在表中进行限制,满足上面条件的数据就不能插入到表中。这就是“约束”。

创建表完毕后查看表结构,可以看到这两个字段是不允许为空的。如下:

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

2. 默认值

默认值:某一种数据会经常性的出现某个具体的值,可以在一开始就指定好,在需要真实数据的时候,用户可以选择性的使用默认值。

        比如创建一个用户表,表当中包含用户的姓名、年龄和性别,将用户的年龄默认设置成18,将用户的性别默认设置成男。如下: 

创建表完毕后查看表结构,可以看到默认值已经设置成功了。如下:

向表中插入数据时,如果不指明用户的年龄或性别,那么就会使用给定的默认值,如果指明了就会使用用户指定的值。如下:

对一个字段同时设置not null 和 default 

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

3. 列描述

列描述:comment,没有实际含义,专门用来描述字段,会根据表创建语句保存,用来给程序员或DBA来进行了解。(你可以理解为注释)

 创建表完毕后,通过下面的SQL语句看到创建表时的相关细节,包括列描述。如下:

#查看创建表时详细的细节
show create table 表名

4. zerofill

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

比如创建一个表,表当中包含a和b两列整型数据,将它们的显示宽度都设置成8,但是没有设置zerofill属性。如下: 

向表中插入一条记录,指明a和b的值均为10,由于我们没有给a和b字段设置zerofill属性,因此查看表中数据时显示出来的都是10,并没有显示宽度的概念。如下:

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

        zerofill属性的作用就是让数据以特定的方式进行显示而已,数据底层的储存方式并没有发生变化。

5. 主键

主键:primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表中最多只能有一个主键;主键所在的列通常是整数类型。

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

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

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

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

alter table 表名 drop primary key

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

alter table 表名 add primary key(列名)

复合主键

在创建表的时候,在所有字段之后,使用primary key(主键字段列表)也可以创建主键,如果有多个字段作为主键, 可以使用复合主键。

 下面这两列合成主键

 复合主键在插入数据的时候,如果只是某一个冲突了,并不影响,全部冲突才影响插入:

#删除指定表的复合主键
alter table 表名 drop primary key

#用多个列形成复合主键
alter table 表名 add primary key(多个列名)

6. 自增长

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

  1. 向表中插入第一条记录时如果没有指明自增长字段的值,那么自增长字段的值默认将会从1开始。
  2. 后续向表中插入记录时如果也不指明自增长字段的值,那么自增长字段的值就会依次递增。
  3. 当然,插入记录的时候也可以指明自增长字段的值,此时将会使用该值进行插入,但注意指明的值不能和表中已有的id值重复。
  4. 此后向表中插入记录时如果又不指明自增长字段的值,那么自增长字段的值将会从id列中找出最大值,将最大值加一后得到的值作为自增长字段的值进行插入。

7. 唯一键

        一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多个字段需要唯一性约束的问题。唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较。
唯一键和主键的区别:
我们可以简单理解成,主键更多的是标识唯一性的。而唯一键更多的是保证在业务上,不要和别的信息出现重复。

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

表创建完毕后查看表结构,可以看到tel的Key列出现了UNI标志,这就表明tel已经成功被设置成唯一键了。如下:

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

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

8. 外键

外键用于定义主表从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。

语法:

foreign key (字段名) references 主表(列)

比如先创建一个班级表作为主表,表当中包含班级的id和班级名,并将班级id设置为主键。然后创建一个学生表作为从表,表当中包含学生的id、姓名以及学生所在班级对应的id,并将学生表中的班级id列设置成外键,关联到班级表中的班级id列。如下:

表创建完毕后查看学生表的表结构,可以看到学生表中的班级id对应的Key列出现了MUL标志,这表明class_id已经成功被设置成了外键。如下:

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

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

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

这时如果向班级表中插入班级id为103的班级信息,然后再向学生表中插入上述记录,这时就允许插入了。如下:

外键约束:

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

9. 综合案例

有一个商店的数据,记录客户及购物情况,有以下三个表组成:
  • 商品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)
要求:
  • 每个表的主外键
  • 客户的姓名不能为空值
  • 邮箱不能重复
  • 客户的性别(男,女)

首先我们需要先创建一个数据库,然后在该数据库中完成这三张表的创建。如下: 

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

 商品表创建完毕后查看表结构如下:

创建客户表的时候,将客户编号设置成主键并且可以将其设置成自增长字段,然后给姓名设置not null属性,将邮箱设置成唯一键,将性别设置成enum类型并仅提供男女性别选项,此外,题目虽然没有对身份证做要求,但正常来说身份证也应该保证唯一性,最好也设置成唯一键。如下:

客户表创建完毕后查看表结构如下:

创建购买表的时候,将订单号设置成主键并且可以将其设置成自增长字段,然需要将客户编号和商品编号设置成外键,分别关联到客户表和商品表中的客户编号和商品编号,用外键约束来保证每一个订单的客户编号和商品编号都是存在的。如下:

购买表创建完毕后查看表结构如下:

猜你喜欢

转载自blog.csdn.net/sjsjnsjnn/article/details/128923526
今日推荐