1. 数据库约束
1.2 NULL约束
1.3 UNIQUE:唯一约束
1.4 DEFAULT:默认值约束
1.5 PRIMARY KEY:主键约束(要求:非空,唯一)
但是数据库允许把多个列共同作为一个主键(联合主键)
主键需要分配一个唯一的值,如何进行分配呢?
mysql 提供了一个 自动分配 主键值 方式,“自增主键”auto_increment
插入数据时,可以不指定id列的值,让数据库自动分配.,就会按照1,2,3,4 ......
也能手动指定其他数值.
在mysql中,给每个表都记录了一个“自增主键的最大值”
后续继续插入数据,无论之前的最大值是否仍然存在
都是根据之前保存的最大值,继续往后分配的.
自增主键只能针对,像int/bigint整数使用
是有可能会使用字符串作为主键的.
部分情况下,都是用数字作为主键.
1.6 FOREIGN KEY:外键约束
案例:
此时,外键约束就出现了
再次往student 中插入数据,就务必要确保
插入的数据的classes_ld的值,得在classes表中存在.
学生表的 classld 列,引用自 班级表的classld 列
班级表中的 数据,约束了/制约了学生表的数据
制约 被制约的一方
父表 子表
如果父表中的某个记录,被子表引用了,此时就不能删除/修改父表中的 对应记录了.
父表是约束了子表,
子表也会对父表反向进行约束.
主键本身也是有“唯一性要求的”
频繁触发查询,此处数据库就会对主键约束,给出特殊的处理.
加快查询四度
数据库会针对 主键 列创建索引
如果不指定主键,是一个unique,也能达成类似的效果
1.7 CHECK约束(了解)
2. 表的设计
2.1 一对一
设计表的做法:
a)搞一个表,同时包含学生和账号的信息.
student account (studentld, name, accountName, password ..... )
b)搞两个表,使用id来进行联系.
student(studentld, name , accountld)
account(accountld, accountName, password)
student(studentld, name )
account(accountld, accountName, password , studentld)
2.2 一对多
一个账号只能属于一个学生
可以使用同一张表,也可以使用两张表(通过一个id,联系)
b)一对多关系
一个学生只能属于一个班级
一个班级可以包含多个学生
这个方案在MySQL中是不可行的.但是在有的数据库中(Redis是可行的)
学生表(学生id,学生姓名 ... ,班级 id)
1 张三 100
2 李四 101
3 王五 100
班级表(班级id,班级名称)
100 java100
101 java101
班级表(班级id,班级名称,学生id列表)
100 java100 1,3
101 java101 2相当于“数组”类型
mysql不支持这样的类型
2.3 多对多
引入关联表,通过关联表把多对多关系表示出来
学生-课程表(学生id,课程id)
1 100 张三选择了语文
1 101 张三选择了数学
1 102 张三选择了英语
2 100 李四选择了语文
2 101 王五选择了教学
如果您觉得有失偏颇请您在评论区指正,如果您觉得不错的话留个好评再走吧!!
您的鼓励就是对我最大的支持! ! !