表的约束
为什么要有约束?
我们在收集一些数据的时候会要求该数据必须存在
比如说像是国家在登记公民信息的时候身份证一栏是必须要填写的不能为空
真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合
法性,从业务逻辑角度保证数据的正确性。比如有一个字段是email,要求是唯一的
表的约束很多,这里主要介绍如下几个: null/not null,default, comment, zerofill,primary
key,auto_increment,unique key 。
空属性
数据库默认字段基本都是字段为空,但是实际开发时,尽可能保证字段不为空,因为数据为空没办法参与运算
所以说对于一些属性我们要设置为非空
语法
not null
实例
我们这里创建一个班级表 其中包含班级名和所在的教室
在外面正常的逻辑中 班级和教室都是不能为空的
- 如果班级名为空我们就不知道自己在哪个班
- 如果教室为空我们就不知道自己在哪个教室
所以说我们在设计数据表的时候加上非空约束
默认值
默认值:某一种数据会经常性的出现某个具体的值,可以在一开始就指定好,在需要真实数据的时候,
用户可以选择性的使用默认值。
语法
default xxx
我们插入一个数据尝试
我们这里只插入了值zhangsna但是age和sex都自动填写了
有了default之后还需要设置非空嘛?
不需要 因为如果我们没有填值的话 系统会给我们填上默认值 所以说就不存在空值的情况了
列描述
列描述:comment,没有实际含义,专门用来描述字段,会根据表创建语句保存,用来给程序员或DBA来进行了解。
语法
comment ‘xxx’
此外我们可以通过查看创建语句来看到对于每个列的描述
实例
zerofill
刚开始学习数据库时,很多人对数字类型后面的长度很迷茫
比如说在下图中 int类型后面的11是什么意思呢?
整型不是4字节码?这个10又代表什么呢?其实没有zerofill这个属性,括号内的数字是毫无意义的
此时我们修改t8中age类型的属性 在后面加上zerofill
此时我们发现age的18前面补上了三个0
也就是说zerofill的意义其实是看该类型有没有达到指定的位数 如果没有达到就在前面加上0填充
主键
主键:primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表中最多只能有一个主键;主键所在的列通常是整数类型。
语法
primary key
实例
我们创建一张表 id作为主键 name作为非空列
主键中的值不能重复 一旦重复就会报错 下面是示例
我们可以看到插入重复id时sql直接报错了
删除主键
语法
alter table 表名 drop primary key;
添加主键
语法
alter table 表名 add primary key(字段列表)
复合主键
在创建表的时候,在所有字段之后,使用primary key(主键字段列表)来创建主键,如果有多个字段
作为主键,可以使用复合主键
比如说在创建学生的课程表的时候学生id和课程号都是可以重复的 但是学生id和课程号的组合确是不能重复的 所以说我们要将他们设置为复合主键
语法
primary key(xxx , yyy)