博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle笔记(十六) 数据库设计范式
阅读量:6377 次
发布时间:2019-06-23

本文共 3097 字,大约阅读时间需要 10 分钟。

数据库设计范式是一个很重要的概念,但是这个重要程度只适合于参考。使用数据库设计范式,可以让数据表更好的进行数据的保存,因为再合理的设计,如果数据量一大也肯定会存在性能上的问题。所以在开发之中,唯一可以称为设计的宝典 —— 设计的时候尽量避免日后的程序出现多表关联查询。

一、第一范式

所谓的第一范式指的就是数据表中的数据列不可再分。

例如,现在有如下一张数据表:

CREATE TABLE member (  mid NUMBER PRIMARY KEY,  name VARCHAR2(200) NOT NULL,  contact VARCHAR2(200));

这个时候设计的就不合理,因为联系方式由多种数据所组成:电话、地址、email、手机,邮政编码,所以这种设计是不符合的,现在可以修改设计:

CREATE TABLE member (  mid NUMBER PRIMARY KEY,  name VARCHAR2(200) NOT NULL,  address VARCHAR2(200),  zipcode VARCHAR2(6),  mobile VARCHAR2(20),  tel VARCHAR2(20));

但是在这里面有两点需要说明:

  • 第一点,关于姓名,在国外的表设计中,姓名也分为姓和名两类,但是在中国就是姓名保存;
  • 第二点,关于生日,生日有专门的数据类型(DATE),所以不能将其设置为生日年,生日月,生日日;

所谓不可分割指的是所有的数据类型都使用数据库提供好的各个数据类型。

二、第二范式:多对多

第二范式:数据表中的非关键字段存在对任一候选关键字段的部分函数依赖;

第二范式分为两种方式理解:

  • 理解一:列之间不应该存在函数关系,现在有如下一个设计:
CREATE TABLE orders (  oid NUMBER PRIMARY KEY,  amount NUMBER,  price NUMBER,  allprice NUMBER);

现在的商品总价(allprice)=商品单价(price)*商品数量(amount),所以存在了函数的依赖关系;

  • 理解二:通过一个数据表的设计体现一下,完成一个学生选课系统,如果说现在按照第一范式,则如下:
CREATE TABLE studentcourse (  stuid NUMBER PRIMARY KEY,  stuname VARCHAR2(20) NOT NULL,  cname VARCHAR2(50) NOT NULL,  credit NUMBER NOT NULL,  score NUMBER);INSERT INTO studentcourse (stuid,stuname,cname,credit,score) VALUES (1,'张三','Java',3,89);INSERT INTO studentcourse (stuid,stuname,cname,credit,score) VALUES (2,'李四','Java',3,99);INSERT INTO studentcourse (stuid,stuname,cname,credit,score) VALUES (3,'王五','Java',3,78);INSERT INTO studentcourse (stuid,stuname,cname,credit,score) VALUES (1,'张三','Oracle',1,79);INSERT INTO studentcourse (stuid,stuname,cname,credit,score) VALUES (2,'李四','Oracle',1,89);

这种设计符合于第一设计范式,但是不符合于第二范式,因为程序会存在如下的错误:

  • 数据重复:学生和课程的数据都处于重复的状态,而且最为严重的是主键的设置问题;
  • 数据更新过多:如果说现在一门课程已经有了3000人参加的话,则更改一门课程学分的时候需要修改3000条记录,肯定性能上会有影响;
  • 如果一门课程没有一个学生参加,这门课程就从学校彻底消失了;

如果要想解决此问题,则可以将数据表的设计修改如下:

CREATE TABLE student (  stuid NUMBER PRIMARY KEY,  stuname VARCHAR2(20) NOT NULL);CREATE TABLE course (  cid NUMBER PRIMARY KEY,  cname VARCHAR2(50) NOT NULL,  credit NUMBER NOT NULL);CREATE TABLE studentcourse (  stuid NUMBER REFERENCES student(stuid),  cid NUMBER REFERENCES course(cid),  score NUMBER);INSERT INTO student (stuid,stuname) VALUES (1,'张三');INSERT INTO student (stuid,stuname) VALUES (2,'李四');INSERT INTO student (stuid,stuname) VALUES (3,'王五');INSERT INTO course (cid,cname,credit) VALUES (10,'Java',3);INSERT INTO course (cid,cname,credit) VALUES (11,'Oracle',1);INSERT INTO course (cid,cname,credit) VALUES (12,'Linux',2);INSERT INTO studentcourse (stuid,cid,score) VALUES (1,10,89);INSERT INTO studentcourse (stuid,cid,score) VALUES (2,10,99);INSERT INTO studentcourse (stuid,cid,score) VALUES (3,10,78);INSERT INTO studentcourse (stuid,cid,score) VALUES (1,11,79);INSERT INTO studentcourse (stuid,cid,score) VALUES (2,11,89);

这种设计与之前讲解运动会-项目-成绩的设计是一样的。

三、第三范式:一对多

例如,现在一个学校有多个学生,如果用第一范式无法实现,而如果用第二范式则表示多对多的关系,即:一个学校有多个学生,一个学生在多个学校,不符合于要求,所以此时可以使用第三范式,参考之前的部门和雇员操作实现,一个部门有多个雇员,所以按照设计编写如下:

CREATE TABLE school (  sid NUMBER PRIMARY KEY,  sname VARCHAR2(20) NOT NULL);CREATE TABLE student (  stuid NUMBER PRIMARY KEY,  stuname VARCHAR2(20) NOT NULL,  sid NUMBER REFERENCES school(sid));

而在实际的工作之中,第三范式的使用是最多的。

以上的三个范式只是作为参考使用。

转载地址:http://agvqa.baihongyu.com/

你可能感兴趣的文章
360该不该拍?
查看>>
用Xib创建控制器
查看>>
oracle的sqlplus和dos的中文乱码问题
查看>>
LVS+keepalived高可用负载均衡集群部署(二)---LAMP网站服务器与LVS服务器
查看>>
Struts2之简单数据类型转换
查看>>
python 打印数字
查看>>
iptables规则的查看、添加、删除和修改
查看>>
打开网站显示输入用户名和密码
查看>>
size_t的32位和64位兼容
查看>>
HBase全分布式模式的安装和配置
查看>>
Spring 框架的设计理念与设计模式分析
查看>>
十年web老兵整理的前端视频资料
查看>>
工作线程数究竟要设置为多少
查看>>
10个Python 统计报表/图表图形类库
查看>>
关于 xargs 参数被截断,tar 文件被覆盖的问题
查看>>
CentOS 6.3 上安装 Oracle 11g R2(转)
查看>>
js实现滚动新闻效果
查看>>
Nginx出现could not build the server_names_hash 解决办法
查看>>
Netbeans8在web项目中创建servlet
查看>>
高可用haproxy调度后端服务器实现动静分离集群架构
查看>>