一 实体关系
在数据库中,常用的实体关系有三种:
一对一、一对多和多对多。
1.1 一对一的实体关系
如果记录的主键值等于另一个关系内记录的主键值,我问称之为一对一的实体关系。
一对一的实体关系(1:1)使得两个表保存的实体之间数据是对等的。
如:一个学生有基本信息和详细信息。
1.2 一对多的实体关系
一对多的实体关系(1:N),A实体对应多个B实体。
如:一个班级内有很多学生,而且一个学生只属于一个班级。
设计:在多的那端,增加一个字段,用于指向该实体所属的另外的实体的标识。
1.3 多对多的实体关系
例:一个讲师可以给多个班级授课。同时一个班级可以由多个来授课
设计:利用一个中间表,标识实体之间的对应关系,中间表的每个记录,标识一个关系,其
实质还是一对多的关系。
二 外键
概念:如果一个实体的(student)的某个字段(student:class_id),指向(引用)另个实体(class)的主键(class:class_id),就称 Student实体的class_id是外键。
被指向的实体,称之为 主实体(主表),也叫父实体(父表)。class
负责指向的实体,称之为 从实体(从表),也叫子实体(子表)。Student
负责指向的实体,称之为 从实体(从表),也叫子实体(子表)。Student
作用:
- 保证数据的完整性。
- 用于约束处于关系内的实体。
- 增加子表记录时,是否有与之对应的父表记录。
- 在删除或者更新主表记录时,从表应该如何处理相关的记录。
2.1 定义一个外键
MySQL中,可以对