关系型数据库设计——E-R图
一、数据管理技术的三个发展阶段:
1)人工管理阶段(20世纪50年代中期) 特点:数据不保存;应用程序管理数据;数据不共享;数据没有独立性;
2)文件系统阶段(20世纪50年代后—60年代)特点:数据以文件形式长期保存;文件系统管理数据;数据共享性差、冗余度大;数据独立性差;
3)数据库系统阶段(20世纪60年代—现在)特点:数据结构化;数据由DBMS统一管理与控制;数据共享性高、冗余度低;数据独立性高;
二、数据库管理系统的功能:
1)数据定义功能:由DBMS提供的数据定义语言(Data Definition Language,DDL)定义数据库中的数据对象。
2)数据操纵功能:由DBMS提供的数据操纵语言(Data Manipulation Language,DML)实现对数据库的查询、插入、删除和修改;
3)数据控制功能:由DBMS提供的数据控制语言(Data Control Language,DCL)实现数据保护和事务管理的功能,包括完整性、安全性、并发控制和数据库恢复;
4)数据库的建立与维护功能
三、概念模型(也称信息模型)——E-R图(Entity-Relationship Diagram)
概念结构设计即对现实世界进行抽象描述,在需求分析所得数据流图和数据字典的基础上,为计算机存储做准备;概念结构设计的内容即建立概念模型;描述概念模型最常用方法是E-R图或UML图方法。
主要概念:
实体(Entity):客观存在的各类事物;
属性(Attribute):实体所具有的特性;
联系(Relationship):不同实体集中实体之间的联系,也可以是同一实体集中实体间的联系;
联系的种类:1:1联系;1:N联系;M:N联系
用E-R图建立概念模型


局部的E-R图又称为局部视图,将多个局部视图E-R图合并成一张完整的E-R图的过程称为视图集成。视图集成过程中可以解决冲突和消除冗余;
分E-R图之间的三类冲突:
1)属性冲突
2)命名冲突
3)结构冲突:同一实体在不同的分E-R图中有不同的属性,同一对象在某一分E-R图中被抽象为实体而在另一分E-R图中又被抽象为属性,需要统一;
四、逻辑结构设计——E-R图向关系模型的转换
1)一个实体转换为一个关系模式;
实体的属性——>关系的属性
实体标识符——>关系的码
2)联系的转换
1:1联系——与任意一端对应的关系模式和并;
1:n联系——与n端对应的关系模式合并;
m:n联系——一个独立的关系模式
五、关系模式的优化
从以下几方面:
1)关系模式规范化
2)对关系模式进行必要的合并
3)进行合理的分解,包括水平分解、垂直分解
六、关系模式的存取方法选择
DBMS常用存取方法:
1)索引方法,目前主要是B+树索引方法
2)聚簇(cluster)方法
3)Hash方法
七、SQL数据库的三级结构/两级映像
三级模式体系结构:

两级映像:
外模式/模式映像
模式/内模式映像
1)数据的逻辑独立性
应用程序(外模式)与数据库的逻辑结构(模式)是相互独立的,即数据的逻辑结构发生改变,应用程序不用变。
2)数据的物理独立性
应用程序(外模式)与存储在磁盘上的数据库文件中的存储结构(内模式)是相互独立的,即数据文件的组织方式改变不需要修改应用程序。
注:数据库的存储结构有哪些?
欢迎交流与指正!*~* *~*
关系型数据库设计——E-R图的更多相关文章
- 数据库系统(四)---关系型数据库设计及E-R图
		1.关系型数据库: 关系型数据库是一类采用关系模型作为逻辑数据模型的数据库系统,遵从数据库设计的基本步骤,包括:需求分析.概念结构设计.逻辑结构设计.物理结构设计.数据库实施.数据库的运行和维护等阶段 ... 
- 基于E-R模型的关系型数据库设计方法
		摘要 在管理信息系统开发中,数据库设计的目标是建立DBMS能识别的关系数据模型.而关系数据模型建立的基础是首先建立E-R模型,通过E-R模型才能转换为关系数据模型.如何建立E-R模型以及如何将E-R模 ... 
- 关系型数据库查询语言 SQL 和图数据库查询语言 nGQL 对比
		摘要:这篇文章将介绍图数据库 Nebula Graph 的查询语言 nGQL 和 SQL 的区别. 本文首发于 Nebula Graph 官方博客:https://nebula-graph.com.c ... 
- 优化MySchool数据库设计之【巅峰对决】
		优化MySchool数据库设计 之独孤九剑 船舶停靠在港湾是很安全的,但这不是造船的目的 By:北大青鸟五道口原玉明老师 1.学习方法: 01.找一本好书 初始阶段不适合,可以放到第二个阶段,看到知识 ... 
- 非关系型数据库Nosql的优缺点分析
		Nosql的全称是Not Only Sql,Nosql指的是非关系型数据库,而我们常用的都是关系型数据库.就像我们常用的mysql,oralce.sqlserver等一样,这些数据库一般用来存储重要信 ... 
- 初识关系型数据库(SQL)与非关系型数据库(NOSQL)
		一.关系型数据库(SQL): Mysql,oracle 特点:数据和数据之间,表和字段之间,表和表之间是存在关系的 例如:部门表 001部分, 员工表 001 用户表,用户名.密码 分类表 和 商 ... 
- 小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_1-4.在线教育后台数据库设计
		笔记 4.在线教育后台数据库设计 简介:讲解后端数据库设计 ,字段冗余的好处,及常见注意事项 1.数据库设计: er图: 实体对象:矩形 ... 
- [MySQL] 关系型数据库的设计范式 1NF 2NF 3NF BCNF
		一.缘由: 要做好DBA,就要更好地理解数据库设计范式.数据库范式总结概览: 为了更好地理解数据库的设计范式,这里借用一下知乎刘慰老师的解释,很通俗易懂.非常感谢! 二.具体说明: 首先要明白”范 ... 
- 关系型数据库与Key-value型数据库Mongodb模式设计对比
		MongoDb 相比于传统的 SQL 关系型数据库,最大的不同在于它们的模式设计( Schema Design )上的差别,正是由于这一层次的差别衍生出其它各方面的不同. 我们可以简单的认为关系型数据 ... 
随机推荐
- 前端之CSS——CSS选择器
			一.CSS介绍 为什么需要CSS(CSS的作用)? 在没有CSS之前,我们想要修改HTML元素的样式需要为每个HTML元素单独定义样式属性,当HTML内容非常多时,就会定义很多重复的样式属性,并且修改 ... 
- vue——组件
			一.组件概念 vue的核心基础就是组件的使用,玩好了组件才能将前面学的基础更好的运用起来.组件的使用更使我们的项目解耦合.更加符合vue的设计思想MVVM. // 定义一个名为 button-coun ... 
- 关于input 中 hidden属性在后台作用的实例
			在双模的项目中,我遇到了一个问题,我公司的双模项目是基于ECShop的框架,在完成订单列表的页面时,我写了两个form表单来单独传输数据,第一个表单是用来做搜素的,第二个表单是用来显示表单信息的,在控 ... 
- 如何angular过滤器进行排序???
			首先定义一个json文件: 然后写HTML文件: <div id="box"> <!--第一个下拉框--> <select ng-model=&quo ... 
- php *-devel
			源码编译安装个php,缺少好多-devel的库. why devel? devel包至少包括头文件和链接库.如果你的要安装的源码依赖某个库,那肯定需要这两样东西. 让apache支持php 在编译ph ... 
- .NET开源工作流RoadFlow-表单设计-隐藏域
			隐藏域即<input type="hidden" value=""/>标签: 
- 使用 Python 设置数据的路径
			使用 Python 设置数据的路径 编程语言(如 Python)将反斜线 (\) 用作转义字符.例如,\n 表示换行符,\t 表示制表符.指定路径时,可使用正斜线 (/) 代替反斜线.使用两条反斜线( ... 
- MySQL代码备份
			package com.dus.utils; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io. ... 
- C#中将dll汇入exe z
			用了3层架构,运行目录下有很多dll文件,最终发布时,我打算将dll文件都合并到exe文件中去.微软发布的免费软件ILmerge可以完成这项工作,研究了一下,其用法如下: 1.合并file1.dll. ... 
- C#转Java之路之三:多线程并发容器即线程安全的容器
			CopyOnWriteArrayList 和 CopyOnWriteArraySet: 是java中两个比较重要的并发容器.适用于读多于写的场景,且集合数据不太大的场合. 特别是CopyOnWrite ... 
