Oracle学习笔记之一,重温范式
第一范式(1NF)
第一范式是第二和第三范式的基础,是最基本的范式。第一范式包括下列的指导原则:
- 数据组的每个属性只可以包含一个值。
- 关系中的每个数组必须只包含相同数量的值。
- 关系中的每个数组一定不能相同。
在任何一个关系数据库中,第一范式是对关系模式的基本要求,不满足第一范式的数据库就不是关系型数据库。
表1.1 不符合第一范式的学生信息表
|
学号 |
姓名 |
性别 |
年龄 |
班级 |
|
9527 |
东*方 |
男 |
20 |
计算机系3班 |
因为上表中的班级属性中包含了多个值,所以它不符合第一范式。改进后的结构如下表所示:
表1.2 符合第一范式的学生信息表
|
学号 |
姓名 |
性别 |
年龄 |
系别 |
班级 |
|
9527 |
东*方 |
男 |
20 |
计算机 |
3班 |
第二范式(2NF)
第二范式是第一范式的基础上建立起来的,即满足第二范式必先满足第一范式。第二范式要求数据库中的每个实体(即各个记录行)必须可以被唯一地区分。要求实体的属性完全依赖于主关键字,即不能存在仅依赖主关键字一部分的属性。
不符合第二范式的示范(员工工资表):
(员工编号,岗位)-》(决定)(姓名、年龄、学历、基本工资、绩效工资、资金)
不符合的原因是,在上面的关系中,还可以进一步拆分为如下两种决定关系:
(员工编号)-》(决定)(姓名、年龄、学历)
(岗位)-》(决定)(基本工资)
符合第二范式的示范(将上面的表拆分为三张表):
员工档案表:EMPLOYEE(员工编号、姓名、年龄、学历)
岗位工资表:QUARTERS(岗位、基本工资)
员工工资表:PAY(员工编号、岗位、绩效工资、奖金)
第三范式(3NF)
第三范式是在第二范式的基础上建立起来的,即满足第三范式必先满足第二范式。第三范式要求关系表不存在非关键字列对任意候选关键字列的传递函数依赖,也就是说,第三范式要求一个关系表中不包含已在其他表中已包含的非主关键字信息。
示范:
(员工编号)-》(决定)(员工姓名、年龄、部门编号、部门经理)
上面的这个关系是符合第二范式的,但它不符合第三范式,因为该关系表内部隐含着如下决定关系:
(员工编号)->(决定)(部门编号)-》(决定)(部门经理)
上面的关系表存在非关键字段“部门经理”对关键字“员工编号”的传递函数依赖。
更改为符合第三范式关系:
员工信息表:EMPLOYEE(员工编号、员工姓名、年龄、部门编号)
部门信息表:DEPARTMENT(部门编号、部门经理)
对于关系数据库的设计,理想的设计目标是按照“规范化”原则存储数据,因为这样做能够消除数据冗余、更新异常、插入异常和删除异常。
Oracle学习笔记之一,重温范式的更多相关文章
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- oracle学习笔记第一天
oracle学习笔记第一天 --oracle学习的第一天 --一.几个基础的关键字 1.select select (挑选) 挑选出显示的--列--(可以多列,用“,”隔开,*表示所有列),为一条 ...
- Oracle学习笔记——点滴汇总
Oracle学习笔记——点滴汇总 http://www.botangdb.com/ Oracle GI = Grid Infrastructure = ASM + Cluster
- Oracle学习笔记之四sp1,Oracle 11g的常用函数
从Oracle学习笔记之四,SQL语言入门中摘出来的,独立成一章节 3.1 字符类函数 ASCII(c)和CHR(i) 分别用于返回一个字符的ASCII码和返回给定ASCII值所对应的字符. C ...
- Oracle学习笔记之四,SQL语言入门
1. SQL语言概述 1.1 SQL语言特点 集合性,SQL可以的高层的数据结构上进行工作,工作时不是单条地处理记录,而对数据进行成组的处理. 统一性,操作任务主要包括:查询数据:插入.修改和删除数据 ...
- Oracle学习笔记—数据字典和常用命令(转载)
转载自: oracle常用数据字典和SQL语句总结 Oracle常用命令大全(很有用,做笔记) 一.Oracle数据字典 数据字典是Oracle存放有关数据库信息的地方,其用途是用来描述数据的.比如一 ...
- oracle学习笔记(一)用户管理
--oracle学习第一天 --连接 @后面连接数据库实例,具体连接到那个数据库 conn scott/tiger@MYORA1; --修改密码 passw; --显示用户 show user; -- ...
- 吴裕雄--天生自然 oracle学习笔记:oracle理论学习详解及各种简单操作例子
1. 数据库的发展过程 层次模型 -->网状模型 -->关系模型 -->对象关系模型 2. 关于数据库的概念 DB:数据库(存储信息的仓库) DBMS:数据库管理系统(用于管理数据库 ...
- 【Oracle】曾经的Oracle学习笔记(8-15)ER图,三大范式,数据库字典,视图,索引,序列
一.数据库建模 二.建表 三.数据库字典 四.DML语句 五.视图 六.索引 七.序列 八.DDL语句 Lesson 8 Overview of Data Modeling and Database ...
随机推荐
- 怎么调用html5的摄像头,录音,视频?
调用image 即打开相册或调用系统相机: <input type="file" accept="image/*" capture="camer ...
- 监听器(web基础学习笔记二十二)
一.监听器 监听器是一个专门用于对其他对象身上发生的事件或状态改变进行监听和相应处理的对象,当被监视的对象发生情况时,立即采取相应的行动.监听器其实就是一个实现特定接口的普通java程序,这个程序专门 ...
- Java File 与 Bytes相互转换
public static byte[] fileToBytes(String filePath) { byte[] buffer = null; File file = new File(fileP ...
- CSDN日报20170310——《假如我是一行代码》
[程序人生]假如我是一行代码 作者:henry-hacker 我们不止一次在生活中听到"假如我如何如何,我会如何如何"的句式.而这种句式说出来的一般意义无非就是让我们站在还有一个角 ...
- C++AMP介绍(一)
C++AMP介绍(一) 最后更新日期:2014-05-02 阅读前提: 环境:Windows 8.1 64bit英文版,Visual Studio 2013 Professional Update1英 ...
- 转:Tkinter教程之Text(2)篇
'''Tkinter教程之Text(2)篇''''''6.使用tag来指定文本的属性'''#创建一个指定背景颜色的TAG# -*- coding: cp936 -*-from Tkinter impo ...
- 克隆server2008R2造成SID冲突
在云上搞的虚拟机,安装5台winserver2008r2,搭域环境,域环境搭好之后,改域用户为管理员,死活更改不成功,之前在测试环境搞域环境时碰到克隆镜像系统全部还原后搭建域环境不成功的情况,后来全部 ...
- python之函数用法getattr()
# -*- coding: utf-8 -*- #python 27 #xiaodeng #python之函数用法getattr() #getattr() #说明: ''' getattr(...) ...
- 使用String 的 intern做锁提高并发能力
一个场景: 某段代码只对同一个ip过来的请求同步处理: 比如ip为a的请求进入了同步代码块,那么后续的ip为a的请求则在代码块外边等着,这时来了一个ip为b的请求,那么这个请求也可以进去,也就是a的所 ...
- 生成CFree 5.0 注册码
C-Free 5.0真是一个很棒的编程软件,可今天用着用着却让我注册,下面的注册码分享给大家: 方法一.下载CFree 5.0之后,直接输入以下信息进行注册. 用户名:tianfang电子邮件:qua ...