MySQL表的约束

目录

一、空属性

二、默认值

三、列描述

四、zerofill

五、主键

六、自增长

七、唯一键

八、外键


  • 真正约束字段的是数据类型,若插入的数据超出了对应数据类型的取值范围,那么数据将会插入失败
  • 数据类型的约束很单一,为了更好的保证数据的合法性,从业务逻辑角度保证数据的正确性,MySQL中出现了表的约束,目的就是为了尽可能保证数据安全,减少用户的误操作可能性
  • 表的约束有很多,本篇博客主要介绍如下几个:null/not null、default、comment、zerofill、primary key、auto_increment、unique key、foreign key

一、空属性

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

MySQL表的约束_第1张图片

由于空值无法参与运算,因此null值加一后得到的还是null

MySQL表的约束_第2张图片

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

MySQL表的约束_第3张图片

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

MySQL表的约束_第4张图片

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

MySQL表的约束_第5张图片

二、默认值

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

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

MySQL表的约束_第6张图片

创建表完毕后查看表结构,可以看到默认值已设置成功

MySQL表的约束_第7张图片

向表中插入数据时,若不指明用户的年龄或性别,那么就会使用对应的默认值,若指明则会使用用户指定的值

MySQL表的约束_第8张图片

同时设置not null和default

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

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

MySQL表的约束_第9张图片

创建表完毕后查看表结构,可以发现id字段不允许为空,并且其默认值是1

MySQL表的约束_第10张图片

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

MySQL表的约束_第11张图片

三、列描述

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

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

MySQL表的约束_第12张图片

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

MySQL表的约束_第13张图片

四、zerofill

zerofill

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

如创建一个表,表中包含a和b两列整型数据,将其显示宽度都设置成5,但只有b设置zerofill属性

MySQL表的约束_第14张图片

向表中插入一条记录,指明a和b的值均为1,由于没有给a字段设置zerofill属性,因此查看表中数据时a显示出来的是1,并没有显示宽度的概念。b列有zerofill属性,由于b列数据的显示宽度为5,因此查看表中数据可以看到b列数据中宽度不足5位的数据都自动在前面填充0

MySQL表的约束_第15张图片

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

MySQL表的约束_第16张图片

五、主键

主键

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

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

MySQL表的约束_第17张图片

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

MySQL表的约束_第18张图片

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

MySQL表的约束_第19张图片

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

MySQL表的约束_第20张图片

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

MySQL表的约束_第21张图片

复合主键

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

如创建一个进程表,表中包含进程的IP地址、端口号和进程的相关信息,并将IP地址和端口号组合形成一个复合主键

MySQL表的约束_第22张图片

创建完毕后查看表结构,可以看到ip和port的Key列都有PRI标志,且都不允许为空

MySQL表的约束_第23张图片

向进程表中插入数据时,只有插入进程的IP和端口均出现冲突时才会产生主键冲突,否则就允许插入

MySQL表的约束_第24张图片

查看表中插入的数据可以看到,表中有重复的IP地址,也有重复的端口号,但是不会出现IP和端口均重复的情况

MySQL表的约束_第25张图片

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

MySQL表的约束_第26张图片

对于已创建好的表,可以使用alter table 表名 add primary key(多个列名)用多个列形成复合主键,但被选取的多个列中的值不能为空且不能同时出现重复。如重新将ip和port设置成进程表的复合主键后再查看表结构,可以看到ip和port对应的Key列的PRI又回来了

MySQL表的约束_第27张图片

六、自增长

  • 设置自增长属性的字段,插入数据时若不给该字段值,那么系统会自动找出当前字段中已有的最大值,将最大值进行加一后的值插入该字段
  • 任何一个字段要做自增长,前提是其本身必须是一个索引(Key一栏有值),且自增长字段必须是数值类型,一张表最多只能有一个自增长字段
  • 自增长通常和主键搭配使用,作为逻辑主键。建议将主键设计成与当前业务无关的字段,避免因为业务逻辑调整而修改主键

如创建一个表,表中包含id和name,将id同时设置成主键和自增长字段

MySQL表的约束_第28张图片

创建表完毕后查看表结构,可以看到id的Extra列中出现了auto_increment标志

MySQL表的约束_第29张图片

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

MySQL表的约束_第30张图片

后续向表中插入记录时若也不指明自增长字段的值,那么自增长字段的值就会依次递增

MySQL表的约束_第31张图片

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

MySQL表的约束_第32张图片

此后向表中插入时若又不指明自增长字段的值,那么自增长字段的值将会找出最大值,将最大值加一后得到的值作为自增长字段的值插入

MySQL表的约束_第33张图片

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

七、唯一键

  • 一张表中往往有很多字段需要唯一性,但一张表中只能有一个主键,而唯一键就可以解决表中有多个字段需要唯一性约束的问题
  • 唯一键和主键都能保证字段中数据的唯一性,但唯一键允许字段为空,并且可以多个字段为空,空字段不做唯一性比较
  • 不是主键具有唯一性,而是某个具有唯一性的字段被选择成为了主键,而那些不是主键但是同样需要唯一性约束的字段就应设置成唯一键

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

MySQL表的约束_第34张图片

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

MySQL表的约束_第35张图片

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

MySQL表的约束_第36张图片

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

MySQL表的约束_第37张图片

八、外键

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

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

MySQL表的约束_第38张图片

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

MySQL表的约束_第39张图片

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

MySQL表的约束_第40张图片

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

MySQL表的约束_第41张图片

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

MySQL表的约束_第42张图片

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

若向班级表中插入班级id为3的班级信息,然后再向学生表中插入上述记录,这时就允许插入了

MySQL表的约束_第43张图片

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

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