自增长
auto_increment:当对应的字段,不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值+1操作,得到一个新的不同的值。通常和主键搭配使用,作为逻辑主键。
自增长的特点:
- 任何一个字段要做自增长,前提是本身是一个索引(key一栏有值)
- 自增长字段必须是整数
- 一张表最多只能有一个自增长
关于索引是什么概念 我们后面的博客会讲解
语法:
auto_increment
下面是实例
我们开始插入名字 之后查看id的变化情况
我们发现id数据是从1开始依次往后递增
那么如果我们现在插入一个id为1000的数据之后的id会如何变化呢?
我们可以发现后面的id从1001开始自增了
唯一键
在了解唯一键之前我们首先要明白一个概念
并不是因为我们选择一个属性成为了主键这个属性才具有了唯一性 而是我们选择了一个具有唯一性的属性成为了主键
也就是说除了主键之间还有很多数据也可能具有唯一性 这也就是我们唯一键出现的原因
语法
unique
下面是实例
当一个数据成为唯一键之后那么这个数据就不能重复了
外键
外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。
当定义外键后,要求外键列数据必须在主表的主键列存在或为null。
我们先来看最后一句加粗的话 也就是说主表中必须有数据从表中才能插入数据
语法:
foreign key (class_id) references myclass(id)
下面是实例 我们先创建主表 之后再从表中创建外键约束
我们首先像从表中插入数据尝试
我们可以发现主表中如果没有插入数据从表中是不能插入的
而主表中有数据 从表中就可以插入数据了
而我们删除数据的时候必须要先删除从表中的数据才能删除主表
这里总结下
- 外键是在从表中定义的
- 从表添加数据必须主表先添加
- 主表删除数据必须从表先删除
我们如何理解外键约束
首先这是一种约束 它肯定是为了防止我们做出错误或不符合逻辑的操作的
理论上,上面的例子,我们不创建外键约束,就正常建立学生表,以及班级表,该有的字段我们都有。
但是实际过程中由于可能会由于人为操作的失误而造成一些错误 比如说一些数据只有学生表中有 而不存在于班级表中(这样就不知道这个学生在哪个班了)
所以说我们添加外键约束是必须的 它的本质其实就是将插入和删除数据的合法性交给mysql去审核
总结