## 关系
* 创建成绩表scores,结构如下
* id
* 学生
* 科目
* 成绩
* 思考:学生列应该存什么信息呢?
* 答:学生列的数据不是在这里新建的,而应该从学生表引用过来,关系也是一条数据;根据范式要求应该存储学生的编号,而不是学生的姓名等其它信息
* 同理,科目表也是关系列,引用科目表中的数据
![](https://box.kancloud.cn/ab4a3919220ff11d67cdbb014f81e007_925x444.png)
* 创建表的语句如下
~~~
create table scores(
id int primary key auto_increment,
stuid int,
subid int,
score decimal(5,2)
);
~~~
## 外键
* 思考:怎么保证关系列数据的有效性呢?任何整数都可以吗?
* 答:必须是学生表中id列存在的数据,可以通过外键约束进行数据的有效性验证
* 为stuid添加外键约束
~~~
alter table scores add constraint stu_sco foreign key(stuid) references students(id);
~~~
* 此时插入或者修改数据时,如果stuid的值在students表中不存在则会报错
* 在创建表时可以直接创建约束
~~~
create table scores(
id int primary key auto_increment,
stuid int,
subid int,
score decimal(5,2),
foreign key(stuid) references students(id),
foreign key(subid) references subjects(id)
);
~~~
## 外键的级联操作
* 在删除students表的数据时,如果这个id值在scores中已经存在,则会抛异常
* 推荐使用逻辑删除,还可以解决这个问题
* 可以创建表时指定级联操作,也可以在创建表后再修改外键的级联操作
* 语法
~~~
alter table scores add constraint stu_sco foreign key(stuid) references students(id) on delete cascade;
~~~
* 级联操作的类型包括:
* restrict(限制):默认值,抛异常
* cascade(级联):如果主表的记录删掉,则从表中相关联的记录都将被删除
* set null:将外键设置为空
* no action:什么都不做
- mysql
- 1.创建库和表
- 1.1.数据库简介
- 1.2.安装管理
- 1.3.数据完整性
- 1.4.命令脚本操作
- 2.查询
- 2.1.条件
- 2.2.聚合
- 2.3.分组
- 2.4.排序
- 2.5.分页
- 3.高级
- 3.1.关系
- 3.2.连接
- 3.3.自关联
- 3.4.子查询
- 3.5.内置函数
- 3.6.视图
- 3.7.事务
- 4.与python交互
- 4.1.交互类型
- 4.2.增改删
- 4.3.查询
- 4.4.封装
- 4.5.用户登录
- Nosql简介
- mongodb
- 1.基本操作
- 1.1.环境安装
- 1.2.数据库操作
- 1.3.集合操作
- 1.4.数据类型
- 1.5.数据操作
- 1.6.数据查询
- 1.6.1.Limit与Skip
- 1.6.2.投影
- 1.6.3.排序
- 1.6.4.统计个数
- 1.6.5.消除重复
- 2.高级操作
- 2.1.聚合aggregate
- 2.1.1.$group
- 2.1.2.$match
- 2.1.3.$project
- 2.1.4.$sort
- 2.1.5.$limit,$skip
- 2.1.6.$unwind
- 2.2.安全
- 2.3.复制(副本集)
- 2.4.备份和恢复
- 2.5.与python交互
- redis
- 1.基本配置
- 2.数据操作
- 2.1.string
- 2.2.键命令
- 2.3.hash
- 2.4.list
- 2.5.set
- 2.6.zset
- 4.高级
- 4.1.发布订阅
- 4.2.主从配置
- 5.与python交互
- 6.login登陆完善