015、数据库设计思想

数据库的设计

参考文献:https://blog.csdn.net/hanxueyu666/article/details/81587199

1、多表之间的关系

         1.1、分类:

                   (1)、一对一(只做了解)

                            * 比如:某个人和它的身份证

                            * 分析:一个人只要一个身份证,一个身份证只能对应一个人。

                   (2)、一对多(或叫多对一)

                            * 如:部门和员工

                            * 分析:一个部门多有个员工,一个员工只能对应一个部门

                   (3)、多对多:

                            * 如:学生和课程

                            * 分析:一个学生可以选择很多课程,一个课程可以被很多学生选择。

         1.2、实现关系

                   (1)、一对一(只做了解)

                            * 比如:某个人和它的身份证

                            * 实现方式:一堆一关系实现,可以在任意放添加 唯一外键 指向另外一方的主键

                   (2)、一对多(或叫多对一)

                            * 如:部门和员工

                            * 实现方式:在‘多’的一方建立外键,执行‘一’的一方的主键,比如在员工表单中建立一个外键执行部门表单中的主键。

                   (3)、多对多:

                            * 如:学生和课程

                            * 实现方式:多对多关系实现需要借助第三方中间表。中间表包含两个字段(联合主键),并使用这两个字段作为外键,分别指向两张表的主键。

2、范式

         (1)概念:要设计数据库,必须遵循一定规范,应用后面的范式必须遵循前面的范式。

设计关系数据库时,遵从不同的规范要求,设计出合理的关系型数据库,这些不同的规范要求被称为不同的范式,各种范式呈递次规范,越高的范式数据库冗余越小。

 

2)、分类

名词解释:

       ①、函数依赖:A->B,如果通过A属性(或属性组)的值,可以确定唯一B属性的值,称B依赖A。

        例如:学号->姓名     (学号,课程名称)->分数

②、完全函数依赖:A->B,如果A是一个属性组,则确定B属性需要依赖于A属性值组中所有的属性值。

例如:(学号,课程名称)->分数

③、部分函数依赖:A->B,如果A是一个属性组,则确定B属性值需要A属性组中的某一些值即可。

④、传递函数依赖:A->B,B->C,如果通过A属性(属性组)的值,可以确定唯一B属性的值,再通过B属性(属性组)的值可以确定唯一的C属性值,则称C传递函数依赖于A.

举例:学号->系名,系名->系主任

:如果一张表中,一个属性或属性组,被其它所有属性完全依赖,则称这个属性(属性组为该表的码):

*主属性:码属性中的所有属性。

*非主属性:除码属性组外的属性。

 

目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴斯-科德范式(BCNF)、第四范式(4NF)和第五范式5NF,又称完美范式)。

a第一范式(1NF数据库表的每一列都是不可分割的原子数据项,而不能是集合,数组,记录等非原子数据项。数据库表的每一列都是不可分割的原子数据项,而不能是集合,数组,记录等非原子数据项。

b、第二范式(2NF)。在第一范式的基础上,消除非主属性对 的部分函数依赖

c、第三范式(3NF)。在2NF基础上消除 传递依赖。

发布了104 篇原创文章 · 获赞 4 · 访问量 7728

猜你喜欢

转载自blog.csdn.net/l0510402015/article/details/104266639
今日推荐