数据库的三种范式介绍和实例

[/color][/size][align=center][/align]
  大家好!介绍一下数据库的三大范式!在学习过程javaWEB编程中逐渐的认识到了数据库设计的重要性!
  数据库可以理解为一组记录的集合,数据库中组织数据的基本单位是表格,一个数据库管理系统可以将不同用途的表组织到一起,统一管理。

   关系数据库设计的核心问题就是关系模型的设计。

[color=red[size=large]]数据库设计范式:

[color=blue]第一范式(1NF)[color=blue][size=large]:数据库表中的字段都是单一属性的,不可再分。这个单一属性由基本数据类型构成,包括整型、实数、字符型、逻辑型、日期型等。无重复的列
例如,如下的数据库是符合第一范式的:
比如说我们记录职工信息的表的时候有(name,age,电话号码)显然这个表不符合第一规范
显然电话号码可以分为办公室号码,和本人电话号码。在确定客户需求时应当尽量顾及到多一些问题。就是每一个单一属性值不能够再分。
[color=blue][size=large]第二范式(2NF)[color=blue][size=large]:
数据库表中不存在非关键字段对任一候选关键字段的部分函数依赖(部分函数依赖指的是存在组合关键字中的某些字段决定非关键字的情况),即所有非关键字段都完全依赖于任意一组获选关键字。假定选课关系表:SelectCourse(学号、姓名、年龄、课程名、成绩、学分),关键字为组合关键字(学号、课程名),因为存在如下决定关系:
(学号,课程名)---->(姓名,年龄,成绩,学分);
这个数据库表不满足第二范式,因为存在如下决定关系:
(课程名)---->(学分)
(学号)---->(姓名,年龄)
即存在组合关键字中的字段决定非关键字的情况。
由于不符合2NF,这个选课关系表会存在如下问题:
(1)数据冗余:
同一门课程由n个学生选修,“学分”就重复了n-1次;同一个学生选修了m门课程,姓名和年龄就重复了m-1次。

(2)更新异常:
若调整了某门课程的学分,数据库中所有行的“学分”值都要更新,否则会出现同一门课程学分不同的情况。

(3)插入异常:
假设要开设一门新的课程,暂时还没有人选修。这样,由于还没有“学号”关键字,课程名称和学分也无法记录入数据库。

(4)删除异常:
假设一批学生已经完成课程的选修,这些选修记录就应该从数据库表中删除。但是与此同时,课程名称和学分信息业被删除了。很显然,这也会导致插入异常。

[size=large]把选课关系表SelectCourse改为如下三个表:
学生:Student(学号、姓名、年龄);
课程:Course(课程名,学分);
选课关系:SelectCourse(学号,课程名称,成绩);
这样的数据库表是符合第二范式的,消除了数据冗余、更新异常、插入异常和删除异常。
另外,所有单关键字的数据库表都符合第二范式,因为不可能存在组合关键字。
[color=blue]第三范式
[size=large]

第三范式(3NF):在第二范式的基础上,数据库中如果不存在非关键字段对任一候选关键字段的传递函数依赖则符合第三范式。所谓传递函数依赖,指的是如果存在“A---->B---->C”的决定关系,则C传递函数依赖于A。因此满足第三范式的数据库表应该不存在如下依赖关系:关键字段---->非关键字段x---->非关键字段y
学生关系表为Student(学号,姓名,年龄,所在学院,学院地点,学院电话),关键字段为单一关键字“学号”,因为存在如下决定关系:
(学号)---->(姓名,年龄,所在学院,学院地点,学院电话)
这个数据库是符合2NF的,但是不符合3NF,因为存在如下决定关系:
(学号)---->(所在学院)---->(学院地点、学院电话)
即存在非关键字段“学院地点”、“学院电话”对关键字段“学号”的传递函数依赖。
它也会存在数据冗余、更新异常、插入异常和删除异常的情况。
把学生关系表分为如下两个表:

学生;(学号、姓名、年龄、所在学院);
学院:(学院、地点、电话)。
这样的数据库表就符合第三范式,消除了数据冗余,更新异常,插入异常和删除异常。
关系
一对一关系
一对多关系
多对多关系
继承关系:比如管理员和用户,这些用户都具有相同的属性,但是又很难像Java一样通过继承增加属性,这个时候我们在设计数据库的时候就的做好数据的冗余规划,尽量将一个实体概念的具体数据保存在一张表中。

ORM映射原理 [/size]
ORM是指将关系型的数据库结构映射到Java实体对象。
Java实体类的设计思想是要完成从关系数据库到Java对象的转换,一般思路是这样的:
一个类对应一个表,表中的一列对应类的一个属性,类的一个对象对应表中的一行数据。这样的类我们一般称之为pojo或者domain类.
如果我做一个BBS 那么我应该做几张表呢?
  首先需要建立一个用户信息的表Userinfo(用户id,登录名,密码,电话号码,邮箱名);
  显然登陆名是关键字。
  其次,要有一张发表博文的表UserBlog(博文id,发表人的id,博文内容,发表时间);
回帖表BlogRes(被回复的博文id号,回复人的id,回帖内容,回帖时间);




你可能感兴趣的:(数据结构,编程,orm,bbs)