为什么需要规范的数据库设计?

什么是数据库设计?

数据库设计就是将数据库中的数据实体及这些数据实体之间的关系,进行规划和结构化的过程.

数据库设计非常重要!

数据库中创建的数据结构的种类,以及在数据实体之间建立的复杂关系是决定数据库系统效率的重要因素

良好的数据库设计:

  1. 效率高
  2. 便于进一步扩展
  3. 可以使应用程序的开发变得更容易

设计数据库的步骤

在需求分析阶段,设计数据库的一般步骤如下:

1.收集信息

2.标识实体

3.标识每个实体的属性

4.标识实体之间的关系

收集信息

创建数据库之前,必须充分理解数据库需要完成的任务和功能

标识实体

在收集需求信息后,必须标识数据库要管理的关键对象或实体

标识每个实体需要存储的详细信息

将数据库中的主要实体标识为表的候选实体以后,就要标识每个实体存储的详细信息

标识实体之间的关系

能够关联数据库中各个项目的相关信息

概要设计-绘制E-R图

实体-关系模型

  1. 实体--------是指现实世界中具有区分其他事物的特征或属性并与其他事物有联系的事物

    2. 属性--------可以理解为实体的特征

    3. 联系--------联系时两个或多个实体之间的关联关系

    实体用矩形表示,一般是名词;

    属性用椭圆表示,一般也是名词;

    联系用菱形表示,一般是动词;

  1. 映射基数--------映射基数表示通过联系与该实体关联的其他实体的个数;
  1. 一对一: X中的一个实体最多与Y中的一个实体关联,并且Y重的一个实体最多与X中的一个实体关联
  2. 一对多: X中的一个实体可以与Y中任意数量的实体关联,Y中的一个实体最多与X中的一个实体关联
  3. 多对一: X中的一个实体最多与Y中的一个实体关联,Y中的一个实体可以与X中的任意数量的实体关联
  4. 多对多: X中的一个实体可以与Y中的任意数量的实体关联
  5. 实体关系图

组成:  1.矩形表示实体集

2.椭圆形表示属性

3.菱形表示联系集

4.直线用来连接属性和实体集,也用来连接实体集和联系集

关系数据库模式

用二维表的形式表示实体和实体间联系的数据模型称为关系模型.关系数据库模式是对关系数据库结构的描述.

表示形式:

R(U) 或者 R(A,B)

R表示关系名,U表示属性集合,A,B代表U中的属性

将E-R图转换为关系模式的步骤如下:

  1. 把每个实体都转化为关系模式R(A,B)形式
  2. 建立实体间联系的转换

实体间的联系分为一对一,一对多,多对多三种,当两个实体各自转化为关系模式后,实体间联系的转换如下:

  1. 一对一的转换:把任意实体的主键放到另一个实体的关系模式中
  2. 一对多的转换:把联系数量为1的实体的主键放到联系数量为N的实体关系模式中
  3. 多对多的转换:把两个实体中的主键和联系的属性放到另一个关系模式中,注意多生成一个关系模式.

逻辑设计-绘制数据库模型图

绘制数据库模型图的步骤

  1. 新建数据库模型图
  2. 添加实体
  3. 添加数据列及相应的属性
  4. 添加实体之间的映射关系

将E-R图转换为数据库模型的步骤如下:

  1. 将E-R图中各实体转化为对应的表,将各属性转化为各表对应的列
  2. 标识每个表的主键列,需要注意的是,要为没有主键的表添加ID编号列,该列没哟实际含义,只用作主键或外键
  3. 在数据库模型图中体现实体之间的映射关系

数据规范化

从关系型数据库表中除去冗余数据的过程称为规范化,如果使用得当,规范化是用于获得高效的关系型数据库表的逻辑结构的最好、最容易的方法。当规范化数据时,应执行下列操作:

  1. 将数据库的结构精简为最简单的形式
  2. 从表中删除冗余的列
  3. 标识所有依赖与其他数据的数据

三大范式内容如下:

  1. 第一范式:其目标是确保每列的原子性
  2. 第二范式:在第一范式的基础上更进一层,其目标是确保表中的每列都和主键相关
  3. 第三范式:在第二范式的基础上更进一层,其目标是确保每列都和主键列直接相关,而不是间接相关

MySQL数据库设计基础的更多相关文章

  1. nodejs进阶(6)—连接MySQL数据库

    1. 建库连库 连接MySQL数据库需要安装支持 npm install mysql 我们需要提前安装按mysql sever端 建一个数据库mydb1 mysql> CREATE DATABA ...

  2. 当忘记mysql数据库密码时如何进行修改

    因为长时间没有使用数据库了,或者把密码改完之后就忘了数据库密码,不能正常进入数据库,也无法修改密码,有一个简单的常用修改密码方式: 1.首先找到和打开mysql.exe和mysqld.exe所在的文件 ...

  3. MySQL数据库和InnoDB存储引擎文件

    参数文件 当MySQL示例启动时,数据库会先去读一个配置参数文件,用来寻找数据库的各种文件所在位置以及指定某些初始化参数,这些参数通常定义了某种内存结构有多大等.在默认情况下,MySQL实例会按照一定 ...

  4. 一起学微软Power BI系列-使用技巧(1)连接Oracle与Mysql数据库

    说起Oracle数据库,以前没用过Oracle不知道,但是这1年用Oracle后,发现真的是想狂吐槽,特别是那个.NET驱动和链接字符串,特别奇葩.总归是和其他数据库不一样,标新立异,不知道为何.另外 ...

  5. CentOS下mysql数据库常用命令总结

    mysql数据库使用总结 本文主要记录一些mysql日常使用的命令,供以后查询. 1.更改root密码 mysqladmin -uroot password 'yourpassword' 2.远程登陆 ...

  6. [原创]java使用JDBC向MySQL数据库批次插入10W条数据测试效率

    使用JDBC连接MySQL数据库进行数据插入的时候,特别是大批量数据连续插入(100000),如何提高效率呢?在JDBC编程接口中Statement 有两个方法特别值得注意:通过使用addBatch( ...

  7. mysql数据库主从同步

    环境: Mater:   CentOS7.1  5.5.52-MariaDB  192.168.108.133 Slave:   CentOS7.1  5.5.52-MariaDB  192.168. ...

  8. PDO连接mysql数据库

    1.PDO简介 PDO(PHP Data Object) 是PHP 5 中加入的东西,是PHP 5新加入的一个重大功能,因为在PHP 5以前的php4/php3都是一堆的数据库扩展来跟各个数据库的连接 ...

  9. mysql数据库开发常见问题及优化

    mysql 数据库是被广泛应用的关系型数据库,其体积小.支持多处理器.开源并免费的特性使其在 Internet 中小型网站中的使用率尤其高.在使用 mysql 的过程中不规范的 SQL 编写.非最优的 ...

随机推荐

  1. Android笔记: 在Eclipse环境下使用Genymotion模拟器

    1.为什么用Genymotion? Genymotion使用x86构架的android系统,在PC上跑起来速度快的飞起,部署速度比真机还快,还有谁? 2.下载Genymotion. Genymotio ...

  2. 微服务从设计到部署(二)使用 API 网关

    链接:https://github.com/oopsguy/microservices-from-design-to-deployment-chinese 译者:Oopsguy 本书的七个章节是关于设 ...

  3. C#异步编程(async and await)及异步方法同步调用

    1.什么是异步? 异步操作通常用于执行完成时间可能较长的任务,如打开大文件.连接远程计算机或查询数据库=异步操作在主应用程序线程以外的线程中执行.应用程序调用方法异步执行某个操作时,应用程序可在异步方 ...

  4. Java基础---继承、抽象、接口

    一.概述         继承是面向对象的一个重要特征.当多个类中存在相同属性和行为时,将这些内容抽取到单独一个类中,那么多个类无需再定义这些属性和行为,只要继那个类即可.这时,多个类可以称为子类,单 ...

  5. PKIX path building failed

    百度这个问题,很多人都说是证书问题.至于是什么证书呢?搞了老半天原来是 /Java/jre/lib/security/cacerts不正确.换了个jdk版本就解决这个问题了. 可靠的jdk1.8下载链 ...

  6. jQuery的基础跟JS的正则

    大家好,我是唯芸星,这是我的一点点学过的知识,呈现给大家                   1:正则表达式 包括: 1:正则表达式包括两部分 ①:定义正则表达式的规则 ②:正则表达式的规模(i/g/ ...

  7. docker的简单搭建(java/tomcat 环境)

    1.一副图简单了解下docker的布局,它是虚拟的,docker分为私服.镜像.容器三个模块 一般从私服pull镜像,镜像run一个容器,我们把容器作为一个虚拟服务,里面可以独立运行进程有独立的内网I ...

  8. java 多线程(0) Java线程

    线程 线程是系统调度的基本单元,每当创建一个进程时,会有许多的线程,也叫轻量级进程,在一个进程中拥有多个线程,各自都有自己的计数器,堆和局部变量属性,并且能够分享内存变量. 为什么要使用多线程  1. ...

  9. 【Beta】阶段 第一次Daily Scrum Meeting

    每日任务 1.本次会议为第一次 Meeting会议: 2.本次会议在周一下午16:40,课间休息时间在禹州楼召开,召开本次会议为10分钟. 一.今日站立式会议照片 二.每个人的工作 (有work it ...

  10. 【Beta】Daily Scrum Meeting——Day3

    站立式会议照片 1.本次会议为第三次Meeting会议: 2.本次会议在早上9:40,在陆大实验室召开,本次会议为25分钟讨论今天要完成的任务以及接下来的任务安排. 燃尽图 每个人的工作分配 遇到的困 ...