数据库设计是数据库知识中比较重要的部分,我们需要了解数据库设计的基本步骤,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——数据库设计的更多相关文章

  1. SQL SERVER学习1——数据库概念

    <SQL Server实例教程>(科学出版社) 数据库的基本概念 数据是载荷信息的物理符号,是数据库中存储的基本对象. 信息可以通过手势,眼神表达,但是表达信息的最佳方式还是数据. 数据有 ...

  2. SQL Server 进阶 01 数据库的设计

    SQL Server 进阶 01 数据库的设计 本篇目录 课程内容回顾及介绍 为什么需要规范的数据库设计 设计数据库的步骤 绘制E-R(实体-关系)图 实体-关系模型 如何将E-R图转换为表 数据规范 ...

  3. SQL server学习(一)数据库的基本知识、基本操作和基本语法

    在软件测试中,数据库是必备知识,假期闲里偷忙,整理了一点学习笔记,共同探讨. 阅读目录 基本知识 数据库发展史 数据库名词 SQL组成 基本操作 登录数据库操作 数据库远程连接操作 数据库分离操作 数 ...

  4. SQL server学习(一)数据库的基本知识、基本操作(分离、脱机、收缩、备份、还原、附加)和基本语法

    在软件测试中,数据库是必备知识,共同探讨. 阅读目录 基本知识 数据库发展史 数据库名词 SQL组成 基本操作 登录数据库操作 数据库远程连接操作 数据库分离操作 数据库脱机.联机操作 数据库收缩操作 ...

  5. 第四篇 SQL Server代理配置数据库邮件

    本篇文章是SQL Server代理系列的第四篇,详细内容请参考原文. 正如这一系列的前几篇所述,SQL Server代理作业是由一系列的作业步骤组成,每个步骤由一个独立的类型去执行.SQL Serve ...

  6. 第七篇 SQL Server安全跨数据库所有权链接

    本篇文章是SQL Server安全系列的第七篇,详细内容请参考原文. Relational databases are used in an amazing variety of applicatio ...

  7. 【译】第七篇 SQL Server安全跨数据库所有权链接

    本篇文章是SQL Server安全系列的第七篇,详细内容请参考原文. Relational databases are used in an amazing variety of applicatio ...

  8. 【译】第四篇 SQL Server代理配置数据库邮件

    本篇文章是SQL Server代理系列的第四篇,详细内容请参考原文. 正如这一系列的前几篇所述,SQL Server代理作业是由一系列的作业步骤组成,每个步骤由一个独立的类型去执行.SQL Serve ...

  9. SQL server学习

    慕课网sql server学习 数据库第一印象:desktop--web server--database server** 几大数据库:sql server.oracle database.DB2. ...

随机推荐

  1. ANE-调用原生组件横屏定位问题

    当我们的应用是横的时候,利用ANE调用原生组件如果处理不当,掉出来的组件会是竖的.那么我么要怎么做才能免去自己手动旋转组件这个破事呢.其实很简单 webView = [[UIWebView alloc ...

  2. 当前安卓App加固到底该如何做到防篡改?

    安卓dalvik虚拟机要求dex文件在内存中以明文形式存在,那么任何加壳方法到头来到了内存还是明文存在,各种dump方法终究是可以获得它的.App究竟应该如何加固才能防止被篡改?   加固和 dump ...

  3. Django-DRF-视图的演变

    版本一(基于类视图APIView类) views.py: APIView是继承的Django View视图的. from .serializers import UserSerializers #导入 ...

  4. 【BZOJ1956】[Ahoi2005]SHUFFLE 洗牌

    题目描述: 这道题,我们首先一眼瞪出来一个规律:对于一个位置为i的牌,在1次洗牌后,他的位置处于(i*2)%(n+1) 的位置 那么,显然的,对于M次洗牌 我们只需要求出2的m次方,这个我们采用快速幂 ...

  5. 【汉化】Acunetix Web Vulnerability Scanner 11.x汉化包

    破解补丁::http://www.52pojie.cn/thread-609275-1-1.html 汉化界面截图: 登陆界面 仪表盘 目标   漏洞 扫描 用户配置 汉化详情: 1.对UI界面大部分 ...

  6. 爬虫6:pyquery库

      强大又灵活的网页解析库,如果觉得正则写起来太麻烦,BeautifulSoup语法太难记,而你又熟悉jQuery的语法,那么用PyQuery就是最佳选择     一. 初始化 1. 字符串初始化 h ...

  7. 我编写 33 个 VSCode 扩展的原因以及管理扩展的经验

    简评:使用工具的同时自己创造一些工具或扩展,是一件很棒的事情. 以下"我"指原作者 Fabio 大家好,我叫 Fabio,是一位自学成才的开发人员,热衷于开源和授权.我也喜欢自己制 ...

  8. docker微服务部署之:五、利用DockerMaven插件自动构建镜像

    docker微服务部署之:四.安装docker.docker中安装mysql和jdk1.8.手动构建镜像.部署项目 在上一篇文章中,我们是手动构建镜像,即: 4.1.2.5.1.2.6.1.2中的将d ...

  9. 创建一个简单的maven的web程序

    最近学习Hadoop,发现学习要想用hadoop作为后台运行web程序,必须应用maven,所以学习了今天学习了一下maven,然后搭建了一个简单的web程序 首先我使用的是eclipse中自带的ma ...

  10. 类型转换 / BOOL 类型

    /* Swift不允许隐式类型转换, 但可以使用显示类型转换(强制类型转换) OC: int intValue = 10; double doubleValue = (double)intValue; ...