范式,NF,normal format,就是指对表的结构的要求!

目的:1,规范结构!2,减少数据冗余!

第一范式,1NF,字段原子性

要求字段不能再分,要求字段的原子性

mysql如何扩张表字段 mysql增加表_MySQL增加范式关系

第二范式,2NF,非部分依赖

增加唯一主键即可!ID

范式的要求,是逐渐递增!

在满足 了 第一范式的前提下,不能出现部分依赖!

部分依赖指的是:普通字段对 主键 是完全依赖的,而不应该是依赖主键的一部分!

依赖:可以通过那个字段去决定另一个字段

因此,出现主键部分依赖的前提是,出现复合主键!

mysql如何扩张表字段 mysql增加表_字段_02

其中代课时间,开始和结束时间,没有部分依赖!称之为完全依赖于主键:

但是,性别,依赖于讲师 字段 即可!

讲师字段是主键的一部分!因此称之为性别 部分依赖于 主键

mysql如何扩张表字段 mysql增加表_主键_03

因此,该表不符合第二范式!

怎么做?

消灭复合主键即可!增加一个唯一字段的主键即可。增加一个与业务逻辑毫无关系的,唯一的ID主键,int unsigned primary key auto_increment

mysql如何扩张表字段 mysql增加表_MySQL增加范式关系_04

第三范式,3NF,非依赖传递

在满足第二范式的前提下,取消传递依赖,就是第三范式!

传递依赖:如果字段B对字段A有依赖,而字段C对字段B存在依赖。则出现了传递依赖!

讲师依赖于ID,而性别依赖于讲师。

班级依赖于ID,而教室依赖于班级。

mysql如何扩张表字段 mysql增加表_mysql如何扩张表字段_05

称之为传递依赖!

解决,要保证所有的字段都完全依赖于主键,而不依赖于其他字段!

将独立的实体信息,使用独立的关系(二维表)进行保存!

分别增加讲师,班级表,将代课信息内的讲师和班级信息拆分出:

mysql如何扩张表字段 mysql增加表_mysql如何扩张表字段_06

总结:

每个实体建立一个表,为每个表增加一个主键ID即可!

一个实体表应该如何设计

实体之间的关系的设计

多个是体表应该如何设计!

实体之间存在哪些关系?

班级,学生两类实体!

一对多,多对一,1:N, N:1

班级,讲师两类实体!

多对多,M:N

学生常用信息,学生不常用信息

一对一,1:1

如何设计?

多对一,一对多

在多的那端(那个表内),增加一个字段,用于保存于当前记录相关联的一端记录的主键!

mysql如何扩张表字段 mysql增加表_MySQL增加范式关系_07

多对多

mysql如何扩张表字段 mysql增加表_字段_08

增加一个专门管理关联的表,使 班级与讲师都与关连表存在联系。从而 是两个实体间有多对多的关系!

mysql如何扩张表字段 mysql增加表_mysql如何扩张表字段_09

因此,一个多对多,会拆分成两个多对一!

一对一

mysql如何扩张表字段 mysql增加表_mysql如何扩张表字段_10

可见,两个表之间存在相同的主键ID即可!

外键约束

约束的作用,是用于保证数据的完整性或者合理性的工具!

外键:foreign key,当前表内,指向其他表的主键的字段,称之为外键!

mysql如何扩张表字段 mysql增加表_MySQL增加范式关系_11

外键约束:用于限制相关联的记录在逻辑上保证合理性的约束称之为外键约束!

约束,不是字段。

建立班级表

mysql如何扩张表字段 mysql增加表_主键_12

再创建学生表

mysql如何扩张表字段 mysql增加表_字段_13

看看删除班级的情况:

mysql如何扩张表字段 mysql增加表_mysql如何扩张表字段_14

出现了不合理数据:

此时,可以通过增加外键约束 的方式,来限制以上的操作!

增加外键

alter table 表名 add constraint 约束的名字 foreignkey 外键索引名字 (外键字段名) references 关联表名 (关联字段) [操作]

mysql如何扩张表字段 mysql增加表_MySQL增加范式关系_15

再删除个试试:

mysql如何扩张表字段 mysql增加表_mysql如何扩张表字段_16

注意:如果当前的数据,已经不符合所见约束关联,则创建失败!

删除外键

alter table table_name drop foreign_key 外键名字!

可以通过 show create table 查看约束的名字:

mysql如何扩张表字段 mysql增加表_mysql如何扩张表字段_17

注意,外键约束与索引的关系:

如果需要在某个字段上,增加外键约束,那么需要该字段也同样有索引!如果该字段上,没有索引,此时,mysql会自动在该字段上增加一个普通索引!

mysql如何扩张表字段 mysql增加表_mysql如何扩张表字段_18

可以选择指定外键约束的名字:

mysql如何扩张表字段 mysql增加表_主键_19

注意上面的外键约束自动建立的索引的名字,与外键的名字相同!

总结:在创建时:

1,外键 与 相应关联表的主键类型

2,已有数据,必须满足约束条件才可以!

3,可以使用constraint 关键字,为外键约束起名字!

约束操作

在对 父表(被关联的表)做操作时,有三种行为:

1,严格限制,拒绝操作。restrict

2,置 null,set null

3,级联操作,cascade

以上三个行为操作,会在主表记录被 删除或者 更新时被使用!

on delete set null

on update cascade

mysql如何扩张表字段 mysql增加表_主键_20

mysql如何扩张表字段 mysql增加表_mysql如何扩张表字段_21

更新时的级联操作:

只有在关联表的主键发生变化时,才会影响到从表的关联字段的变化!

mysql如何扩张表字段 mysql增加表_外键_22

主表:被关联的

从表:发出关联的!

应该注意的问题:

关于,外键约束,只能在当前的 mysql的的 innodb 表类型(引擎)下才会生效!

mysql如何扩张表字段 mysql增加表_外键_23

外键,站在 php程序的角度,用到的不多!