SQL SERVER学习2——数据库设计
数据库设计是数据库知识中比较重要的部分,我们需要了解数据库设计的基本步骤,E-R图的画法。
数据库设计的基本概述
检验一个数据库设计好坏的标准就是,看他是否能够方便的执行各种数据检索和处理操作,并且有利于数据的控制管理和维护。
数据库设计步骤
设计数据库规范中比较著名的是“新奥尔良方法”(这个可不是做新奥尔良鸡腿的方法哦),Now Orleans,总计4个阶段:
- 需求分析(分析用户要求,制作数据流图和判定图)
- 概念结构设计(信息分析和定义,制作E-R图)
- 逻辑结构设计(设计实现,关系型模型,或者非关系型模型)
- 物理结构设计(物理数据库设计,存储安排,存储路径建立)
后来许多科学家经过改良补充,在最后增加了2个步骤:
- 数据库实施阶段(装入数据,数据库试运行)
- 数据库运行和维护(性能检测,备份,恢复,数据库重构)
设计阶段的E-R图
E-R图就是实体-联系图(Entity-Relationship Diagram),用来描述现实世界的概念模型,表示实体类型,数据和联系。
实体
可以是现实世界中的任何可以被认识的事物,可以是人或物,可以是抽象概念,比如一个学生,一台电脑。
属性
实体之间所具有的一系列特征,比如一台电脑的属性可以有商品名称,品牌,型号,价格。
联系
各个实体之间的内部联系,可以分为3类:
一对一(1:1)
对于实体集合a,实体集合b中最多有一个与a联系(可以没有),反之亦然,称他们为一对一关系,就是一一对应。比如,一辆车a有一个车牌号b,一个车牌b对应一辆车a。
一对多(1:n)
对于实体集合a,实体集合b有多个对象联系,就是一对多关系,一个a对应多个b。比如,一个a型号的车可以有很多辆,很多辆车也可以是同一个型号a。
多对多(m:n)
对于实体集合a,实体集合b有多个对象联系,反之亦然。比如,一个人a可以买很多种类的商品,一个种类的商品b也可以买个很多个人。
E-R图例说明
矩形:表示实体
菱形:表示联系
椭圆:表示实体或联系的属性
连线:各个图形之间使用直线连接,并在直线上标注联系类型,一对一(在连线2边都写1),一对多(在连线一的一边写1,多的一边写n),多对多(在连线一边写n,另外一边写m)



逻辑结构转为关系模型
比如一对一关系(1:1):
公司(公司编码,名称,地址)
经理(职工号,姓名,职务名称,公司编码)
比如一对多关系(1:n):
方案1
类型(类型编号,类型名称,级别)
商品(商品编号,商品名称,品牌)
归属(类型编号,商品编号)
方案2
类型(类型编号,类型名称,级别)
商品(商品编号,商品名称,品牌,类型编号)
在这里可以看到,方案1虽然也符合设计的理念,但是关系太多,管理起来不方便,不如关系2简洁。
比如多对多关系(m:n):
买家(买家编号,买家名称,电话)
商品(商品编号,商品名称,品牌)
销售(买家编号,商品编号,销售日期)
数据库实施阶段
数据库实施主要是数据库定义,数据入库,数据库的试运行。设计人员用DBMS提供的数定义语言将数据库逻辑结构和物理结构描述出来,是数据模型成为DBMS可以接受的源代码,建立数据库结构,组织数据入库,数据入库是实施的最主要工作,通常数据量大,耗时多。接着是试运行阶段,就是实际运行应用程序,对数据库进行存储操作,测试应用程序功能是否满足要求。
在试运行阶段,实际测量和评价系统性能指标。
数据库的运行和维护
主要有4个工作:
数据库的备份和恢复
数据库的安全性和完整性控制
数据库性能检测,分析,改造数据库
数据库的重构
SQL SERVER学习2——数据库设计的更多相关文章
- SQL SERVER学习1——数据库概念
<SQL Server实例教程>(科学出版社) 数据库的基本概念 数据是载荷信息的物理符号,是数据库中存储的基本对象. 信息可以通过手势,眼神表达,但是表达信息的最佳方式还是数据. 数据有 ...
- SQL Server 进阶 01 数据库的设计
SQL Server 进阶 01 数据库的设计 本篇目录 课程内容回顾及介绍 为什么需要规范的数据库设计 设计数据库的步骤 绘制E-R(实体-关系)图 实体-关系模型 如何将E-R图转换为表 数据规范 ...
- SQL server学习(一)数据库的基本知识、基本操作和基本语法
在软件测试中,数据库是必备知识,假期闲里偷忙,整理了一点学习笔记,共同探讨. 阅读目录 基本知识 数据库发展史 数据库名词 SQL组成 基本操作 登录数据库操作 数据库远程连接操作 数据库分离操作 数 ...
- SQL server学习(一)数据库的基本知识、基本操作(分离、脱机、收缩、备份、还原、附加)和基本语法
在软件测试中,数据库是必备知识,共同探讨. 阅读目录 基本知识 数据库发展史 数据库名词 SQL组成 基本操作 登录数据库操作 数据库远程连接操作 数据库分离操作 数据库脱机.联机操作 数据库收缩操作 ...
- 第四篇 SQL Server代理配置数据库邮件
本篇文章是SQL Server代理系列的第四篇,详细内容请参考原文. 正如这一系列的前几篇所述,SQL Server代理作业是由一系列的作业步骤组成,每个步骤由一个独立的类型去执行.SQL Serve ...
- 第七篇 SQL Server安全跨数据库所有权链接
本篇文章是SQL Server安全系列的第七篇,详细内容请参考原文. Relational databases are used in an amazing variety of applicatio ...
- 【译】第七篇 SQL Server安全跨数据库所有权链接
本篇文章是SQL Server安全系列的第七篇,详细内容请参考原文. Relational databases are used in an amazing variety of applicatio ...
- 【译】第四篇 SQL Server代理配置数据库邮件
本篇文章是SQL Server代理系列的第四篇,详细内容请参考原文. 正如这一系列的前几篇所述,SQL Server代理作业是由一系列的作业步骤组成,每个步骤由一个独立的类型去执行.SQL Serve ...
- SQL server学习
慕课网sql server学习 数据库第一印象:desktop--web server--database server** 几大数据库:sql server.oracle database.DB2. ...
随机推荐
- Winfrom PictureBox 设置图片自适应
初始状态 Bitmap bm = new Bitmap(Image.FromStream(System.Net.WebRequest.Create(new Uri(result.Result)).Ge ...
- ASP.NET基于NPOI导出数据
using System; using System.Collections; using System.Collections.Generic; using System.IO; using Sys ...
- WPF Adorner 在TabControl切换TabItem时消失
错误的截图: 一开始以为是MVVM绑定的代码中出现了问题,但是通过断点追踪并没有发现问题. 通过通过VS的实时可视化树发现问题:切换Item时Adorner会在AdornerLayer直接消失.届时怀 ...
- CTF中密码学一些基础【三】
本文作者:i春秋签约作家——MAX. 看看今天教程: 看着几个字符在键盘的位置,直接就是三个圈圈,圆心的三个字符就是答案 非常简单! 答案就是KEY 看题解密就好了!! 根据提示Asp encode解 ...
- Activity启动流程
Activity启动过程中做了哪些事情?下面的时序图展示里启动过程中函数的调用过程, 从图中可以知道大概流程. 在介绍细节的时候是从上往下函数调用过程介绍的,如果不知道某个函数是在哪里被谁调用的,可以 ...
- RN47 中通过 JS 调用 Native 方法
每一个模块.方法都有一个 ID,通过 ID 来调用. m_registry->callNativeMethod(call.moduleId, call.methodId, std::move(c ...
- 10分钟教你用Python打造天气机器人+关键字自动回复+定时发送
01 前言 Hello,各位小伙伴.自上次我们介绍了Python实现天气预报的功能以后,那个小程序还有诸多不完善的地方,今天,我们再次来完善一下我们的小程序.比如我们想给机器人发“天气”等关键字,它就 ...
- AssertJ断言系列-----------<数据库断言二>
那么,在实际的接口测试中,我们除了要断言响应的数据正确之外,可能有的还需要断言数据层是否数据真的有入库. assertj db是可以直接对数据库进行断言和操作的. 一.创建一个students表 CR ...
- 调用ajax的返回值,需要再ajax之外的函数体里return,以及同步异步问题
<html> <head> <meta charset="utf-8"/> <script src="js/jquery-1.1 ...
- js 的概念和声明-js 的变量-js 的运算符和逻辑结构-js 的数组
js 的概念和声明Js的概念和声明:问题:在网页的发展历程中,发现网页不能对用户的数据进行自动校验,和提供一些特效造成用户体验极差解决:使用JavaScript作用:可以让网页和用户之间进行直接简单的 ...