MySQL数据库 - 表的约束


目录

1、空属性(null)

2、默认值(default) 

 not null 与 default 

 3、列描述(comment)

 4、zerofill

5、主键(primary key) 

6、复合主键 

 7、自增长(auto_increment)

8、唯一键(unique) 

 9、外键(foreign key)

 10、综合案例


真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性,比如:有一个字段是email,要求是唯一的。

1、空属性(null)

• 两个值:null(默认的)和 not null(不为空)

• 数据库默认字段基本都是字段为空,但是实际开发时,尽可能保证字段不为空,因为数据为空没办法参与运算。

通过 select 可以看到 null 值为 null:

MySQL数据库 - 表的约束_第1张图片

因为空值无法参与运算,所以null + 任何值都是 null:

MySQL数据库 - 表的约束_第2张图片 如果想让某个字段不允许为空,可以在创建表时,添加 not null 属性。

案例:创建一个班级表,包含班级名,以及班级所在的教室,而这两个字段不允许为空,创建表时就可以添加not null 属性:

MySQL数据库 - 表的约束_第3张图片

 此时查看表结构,可以看到这两个字段是不允许为空的:

MySQL数据库 - 表的约束_第4张图片

 此时向表中插入数据,做测试看是否插入成功:

MySQL数据库 - 表的约束_第5张图片


2、默认值(default) 

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

创建一个用户表,表中包含用户的姓名,年龄和性别,将用户的年龄默认设置成为0,性别默认设置为 男 :

MySQL数据库 - 表的约束_第6张图片

通过查看表结构,看设置的默认值是否设置成功:

MySQL数据库 - 表的约束_第7张图片 向表中插入数据,分别测试是否指定插入用户的性别或者年龄,如果不指定是否会使用默认值:

MySQL数据库 - 表的约束_第8张图片


 not null 与 default 

• 某一字段设置了默认值,那么该字段就不会出现空值,因为就算在插入数据时,你没有指明插入到该字段的值,也会使用该字段的默认值进行填充。

• 某一字段设置 not null 属性的目的是约束该字段不能为空,因此一个字段设置了default 属性后,再设置not null 属性就没有意义了,但是 MySQL语法是支持同时设置 not null 与 default 的。

案例:创建一个学生表,表中包含姓名(not null),id (同时设置 not null 和 default)属性:

MySQL数据库 - 表的约束_第9张图片

通过查看表结构,可以看到 id 字段是不允许为空,并且有默认值 10 的:

MySQL数据库 - 表的约束_第10张图片 向表中插入数据,不指明 id 值,将会用默认值:

MySQL数据库 - 表的约束_第11张图片


 3、列描述(comment)

 没有实际含义,专门用来描述字段,会根据表创建语句保存,用来给程序员或者DBA来进行了解的。

案例:创建一个包含,用户名(not null),年龄(default),性别(default)并在每一个字段后面添加上对应的列描述的表结构:

MySQL数据库 - 表的约束_第12张图片

通过 desc 查看表结构 查不到对应的 comment 信息:

MySQL数据库 - 表的约束_第13张图片通过 show 就可以看到:

MySQL数据库 - 表的约束_第14张图片


 4、zerofill

 很多人对数据类型 (int)后面的数字可能跟陌生,比如:

MySQL数据库 - 表的约束_第15张图片

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

案例:创建一个包含 a 和 b 两列 整型数据,将其显示宽度设置为 5,没有加上 zerofill 属性:

MySQL数据库 - 表的约束_第16张图片 此时向表中插入数据,因为没有给 a 和 b 加上 zerofill 属性,所以插入的是多少,显示出来的就是多少:

MySQL数据库 - 表的约束_第17张图片 通过修改表中的结构,加上zerofill 属性,查看相对应的结构:

MySQL数据库 - 表的约束_第18张图片

zerofill 属性的作用只是让数据以特定的方式进行显示,数据的底层的存储方式并没有发生改变,通过 hex 函数(16进制显示)可以查看:

MySQL数据库 - 表的约束_第19张图片


5、主键(primary key) 

 primary key 用来唯一的约束该字段里面的数据,不能重复,不能为空,相当于(unique + not null),一张表中最多只能有一个主键,主键所在的列通常是整数类型。

案例:创建一个 包含id,姓名的表结构,其中 id 设为主键:

MySQL数据库 - 表的约束_第20张图片

通过查看表结构,观察 id 字段被设置成为了 PRI,变成了主键:

MySQL数据库 - 表的约束_第21张图片 主键约束,就是插入进表中的记录的主键字段不能重复,相反,插入进表的数据一定不是重复的,如果重复了,会造成主键冲突,导致插入失败:

MySQL数据库 - 表的约束_第22张图片

 如果需要删除表中的主键约束,使用 alter table 表名 drop primary key 这条SQL语句即可:

MySQL数据库 - 表的约束_第23张图片

如果需要向表中的某个字段添加 主键约束,使用 alter table 表名 add primary key(字段名) 这条SQL语句即可:

MySQL数据库 - 表的约束_第24张图片


6、复合主键 

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

案例:创建一个包含,id,course,score的课程表结构,其中将 id 和 course 组合成为一个复合主键。

MySQL数据库 - 表的约束_第25张图片

通过查看表结构,可以发现 id 字段 和 course 字段都含有 主键约束:

MySQL数据库 - 表的约束_第26张图片 通过插入数据可以知道,有重复的 id + course 时,插入数据会失败:

MySQL数据库 - 表的约束_第27张图片

其中删除主键约束,与添加主键约束与之前一致,只是在添加主键SQL语句中,使用 alter table 表名 add primary key (多个列名) 。


 7、自增长(auto_increment)

 当对应的字段,不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值 +1 操作,得到一个新的不同的值。通常和主键搭配使用,作为逻辑主键。

特点:

• 任何一个字段要做自增长,前提是本身是一个索引(key一栏有值)。

• 自增长字段必须是整数。

• 一张表最多只能有一个自增长。

案例:创建一个包含 id,name 其中 id 设为主键和自增长的表结构:

MySQL数据库 - 表的约束_第28张图片

 通过查看表结构,可以看到主键,以及自增长等约束:

MySQL数据库 - 表的约束_第29张图片

向表中插入数据,在不指明 id 值的情况在,默认id会从 1 开始自增长:

MySQL数据库 - 表的约束_第30张图片 如果指明 id 插入,注意 id 不能与之前的 id 相同,并且后面自增长的 id 值从最新插入的 id 开始自增长。

 在插入后获取上次插入的 auto_increment 的值,使用 last_insert_id () 函数:

MySQL数据库 - 表的约束_第31张图片

通过 show 查看表结构,也可以查看下次 auto_increment 自增长的值从什么时候开始:

MySQL数据库 - 表的约束_第32张图片


8、唯一键(unique) 

 • 一张表中一般有很多字段需要唯一性,数据不能重复情况,但是一张表中只能有一个主键,唯一键就可以解决表中有很多字段需要唯一性约束的问题。

• 唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较。

• 唯一键 和 主键的区别 在与主键更多的表示唯一性的,而唯一键更多是保证在业务上,不要和别的信息出现重复。

案例:创建一个学生表,表中包含 学生 id ,姓名,电话号码 字段,其中把 id 作为主键,因为每个学生的电话号码也是不唯一的,所以添加 唯一键约束:

MySQL数据库 - 表的约束_第33张图片

通过查看表结构,可以看到各个字段的约束条件:

MySQL数据库 - 表的约束_第34张图片 向表中插入数据,如果电话出现重复的情况,就会导致 unique 约束,插入失败:

MySQL数据库 - 表的约束_第35张图片

如果向表中插入的记录不指明唯一键字段的值,此字段默认为空,不做唯一性比较:

MySQL数据库 - 表的约束_第36张图片


 9、外键(foreign key)

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

语法: foreign key (字段名) references 主表 (列)

 案例:先创建班级表作为主表,表中包含 id 和 class_name 字段,并将班级 id 设置为主键:

MySQL数据库 - 表的约束_第37张图片

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

MySQL数据库 - 表的约束_第38张图片

 通过查看表结构,可以看到学生表中的约束条件:

MySQL数据库 - 表的约束_第39张图片

 先向班级表(class)插入两条数据:

MySQL数据库 - 表的约束_第40张图片

再向学生表中插入数据,其中学生表中的 class_id 要与 class 中的 id 对应且存在,或者为 null 也行,此时是允许插入的:

MySQL数据库 - 表的约束_第41张图片 但是如果在student 表中插入的 class_id 在与 class 表中的 id 相对应,插入的数据就是不存在的,此时就会插入失败:


 10、综合案例

有一个商店的数据,记录客户及购物情况,有以下三个表组成:

1、商品 goods (商品编号 goods_id,商品名 goods_name,单价 unitprice,商品类别 category,供应商 provider)。

2、客户 customer(客户号 customer_id,姓名 name,住址 address,邮箱 email,性别 sex,身份证 card_id)

3、购买 purchase (购买订单号 order_id,客户号 customer_id,商品号 goods_id,购买数量 nums)

 

要求:

1、每个表的主外键

2、客户的姓名不能为空值

3、邮箱不能重复

4、客户的性别(男,女)

首先建立数据库:

MySQL数据库 - 表的约束_第42张图片

再创建三张表结构,先建立商品表(goods)表结构:

MySQL数据库 - 表的约束_第43张图片 再建立客户表(customer):

MySQL数据库 - 表的约束_第44张图片

最后建立购买表(purchase):

MySQL数据库 - 表的约束_第45张图片


你可能感兴趣的:(MySQL数据库,数据库,mysql)