表的约束

表的约束:表中一定存在各种约束,通过约束,可以让未来插入数据库中的数据是符合预期的
约束本质是通过技术手段,逼迫用户插入正确的数据
约束的最终目的就是,保证数据的完整性和可预期性
空属性
空属性表示数据是否为空
数据库默认该字段可以为空,但是实际开发时要尽量保证字段不为空

eg.

默认值
默认值:某种值需要在一开始指定好,如果没有给出值,则会使用默认值
default:缺省值,如果一开始就设置好了值,就使用开始确定的值,否则就使用缺省值定义数据
如果同时添加了not null和default
如果没有明确指定一列要插入,用的约束是default
如果建表时,对应列默认没有设置default值,则无法直接插入
default和not null不冲突,而是互补的
如果建立表时,没有指定默认值且灭有设置not null,mysql会自动添加default null



列描述
使用comment可以进行列描述,没有实际含义,本质就是编程语言中的注释
列描述是一种软性的约束

zerofill
zerofill是显示方面的约束
给特定的一列添加zerofill属性,如果显示数据的宽度小于规定宽度
则会在前面补零,让数据等宽
如果位数超过了,就不进行处理,原本是多少就是多少




主键
primary key用来唯一的约束该字段里面的数据,不能重复,不能为空
一张表最多一个主键,主键所在的列通常是整数类型
建表时一般会直接指定主键
一个表最多只有一个主键,但不意味着只有一列可以成为主键
主键可以被添加到一列或多列
此时,这两列合起来才是一个主键
必须有至少一列不同




自增长(通常和主键一起使用)
当对应的字段没有给初始值,系统会自动取当前最大值+1(如果没有值就取1)
得到一个新的值,赋值给该字段
通常和主键搭配作为逻辑主键
在primary key 后+ auto_increment
自增长字段必须是整数,且本身是一个索引
一张表最多只能有一个自增长



唯一键
唯一键可以为空,但是数据不能重复
唯一键的本质和主键差不多,但是主键不允许为空
主键更多用来表示唯一性
而唯一键则是更多的保证,在业务上,不能出现重复的信息


外键
外键用于定义主表和从表之间的关系
外键约束主要定义在从表上
主表上则必须又主键约束或unique约束
定义外键后,要求外键列数据必须在主表列存在或为null
添加foreign key(字段名) references 主表(列)
就可以设置外键约束了
从表中不允许插入外键指定的主表的列中不存在的数据




