Skip to content

数据库设计(Database Design)是指对于一个给定的应用环境,构造最优的数据库模式,建立数据库及其应用系统,使之能够有效地存储数据,满足各种用户的应用需求(信息要求和处理要求)。在数据库领域内,常常把使用数据库的各类系统统称为数据库应用系统。 数据库设计的设计内容包括:需求分析、概念结构设计、逻辑结构设计、物理结构设计、数据库的实施和数据库的运行和维护。

一、范式概述

1.1、什么是范式

好的数据库设计对数据的存储性能和后期的程序开发,都会产生重要的影响。建立科学的,规范的数据库就需要满足一些规则来优化数据的设计和存储,这些规则就称为范式。

1.2、范式分类

目前关系数据库有六种范式:

第一范式(1NF)

第二范式(2NF)

第三范式(3NF)

巴斯-科德范式(BCNF)、

第四范式(4NF)

第五范式(5NF,又称完美范式)

一般说来,数据库只需满足第三范式(3NF)就行了。

二、第一范式

确保每个字段不可再分。确保每列原子性。

案例:

班级表中的字段

mysql
+---------+----------+------------------------+
| 班级id  | 班级名称   |         上课时间        |
+---------+----------+------------------------+
| 1       |    一班   | 1999-09-01~2000-01-04  |
+---------+----------+-------------------------+

不合理。不满足第一范式,上课时间可以再分

mysql
+---------+----------+------------------------+
| 班级id   | 班级名称   |   开课时间  |  结课时间  |
+---------+----------+------------------------+
| 1       |    一班   | 1999-09-01 | 2000-01-04|
+---------+----------+-------------------------+

地址包含省、市、县、地区是否需要拆分? 如果仅仅起地址的作用,不需要统计,可以不拆分;如果有按地区统计的功能需要拆分。一般情况下拆分

三、第二范式

一个表只能描述一件事。

订单表中的字段

mysql
+---------+----------+------------------------+
| 订单编号 | 产品编号   |   订购日期  |    价格    |
+---------+----------+------------------------+
| 00001   | A00001   | 1999-09-01 |   35687.0 |
+---------+----------+------------------------+

不合理。不满足第二范式,一个表中出现了二种描述,一个是订单,一个是产品

mysql
订单表
+---------+------------+
| 订单编号 |   订购日期  |
+---------+------------+
| 00001   | 1999-09-01 | 
+---------+------------+
产品表
+----------+------------+
| 产品编号   |   价格     |
+----------+------------+
| A00001   | 35687.0    |
+----------+------------+

如下表设计是否合理?

+------+--------+--------+---------+----------+
| 学号  | 姓名   |   年龄  | 最高气温 |  青菜价格  | 
+------+--------+--------+---------+----------+

四、第三范式

在所有的非键字段中,不能有传递依赖。消除传递依赖

订单表中的字段

+---------+----------+------------------------+
| 订单编号 | 订购日期   |   顾客编号  |   顾客姓名 |
+---------+----------+------------------------+
| 00001   |1999-09-01|   A000001  |    Luc    |
+---------+----------+------------------------+

不合理。不满足第三范式,因为我们已经可以通过顾客编号知道顾客姓名,所以我们不需要定义顾客姓名

+---------+----------+------------+
| 订单编号 | 订购日期   |   顾客编号  | 
+---------+----------+------------+
| 00001   |1999-09-01|   A000001  | 
+---------+----------+------------+

下列设计是否满足第三范式?

+------+--------+--------+---------+----------+
| 学号  | 姓名   |   语文  |   数学   |  总分    | 
+------+--------+--------+---------+----------+

不满足,因为语文和数学确定了,总分就确定了。 上面的设计不满足第三范式,但是高考分数表就是这样设计的,为什么? 高考分数峰值访问量非常大,这时候就是性能更重要。当性能和规范化冲突的时候,我们首选性能。这就是“反三范式”。

Released under the MIT License.