软件开发流程(CMMI):

1):项目启动;

2):项目计划:

3):需求分析; 需要得到的结果是什么?

4):系统设计;         该怎么做?

5):系统开发;

6):系统测试;

7):系统部署维护

 

软件项目开发周期中的数据库设计

需求分析阶段:      分析客户的业务设计和数据处理需求

概要设计阶段:      设计数据库的E-R模型图,确认需求信息的正确和完整

详细设计阶段:      应用数据库三大范式审核数据库结构

代码编写阶段:      物理实现数据库,编码实现应用

软件测试...................

设计数据库的步骤:

1):收集信息:           充分了解用户需求,理解数据库需要完成的任务

酒店:

客人可以住哪儿房间

2):标识实体:           标识数据库要管理的关键对象

酒店实体:

客人

房间

3):标识实体的属性:     标识数据库要管理的对象的属性

客人:       姓名、身份证、房间号、入住日期、结账日期、押金、总金额

房间:      房间号、房间名称、床位数、房间状态、入住人数、客人类型、价格

4):标识实体与实体之间的关系

跟房间的关系:客人入住房间

绘制E-R图(实体关系图)

组成:

1):实体(使用矩形表示)

2):属性(使用椭圆表示)

3):关系(使用菱形表示)

绘制E-R图工具:Power Designer(推荐)

E-R图的映射基数

一对一

一对多(多对一)

多对多

酒店管理系统E-R图

将E-R图转换成数据模型

1):一对一关系

将一方的主关键字纳入到另一方作为外键。如果关系中有属性的,也一并纳入。

例如:(一个仓库,一类商品)

仓库(名字)

商品(编号、类型)

------》

仓库(名字)

商品(编号、类型、仓库名字)

2):一对多关系

将一方的主关键字纳入到多方作为外键。如果关系中有属性的,也一并纳入。

例如:(一个仓库,多个商品)

仓库(编号、名字、状态)

商品(编号、类型、价格、生产日期等等)

--------》

仓库(编号、名字、状态)

商品(编号、类型、价格、生产日期等等、仓库编号、仓库名字)

3):多对多关系

将双方的关键字纳入到新的一方(第三方)作为外键,如果关系中有属性的,也一并纳入。

例如:

老师(编号,名字)

课程(课程编号、课程名称、课程说明)

---------》

老师(编号,名字)

课程(课程编号、课程名称、课程说明)

授课:(老师编号、老师名字、课程编号、课程名字、课程说明)

数据的规范化

三大范式,最小冗余的表结构。

第一范式:确保每列的原子性。每列不可以在进行分割。

原子性:每列都是不可再分的最小单元。

第二范式: 满足第一范式,除了逐渐以外的列都依赖于该主键.

一张表只描述一件事.

第三范式: 满足第二范式,除了主键以外的列都不传递依赖于主键列.

除了主键以外的其他列都不传递依赖与主键列

 

mysql中数据库的设计的更多相关文章

  1. [MySQL] 关系型数据库的设计范式 1NF 2NF 3NF BCNF

    一.缘由: 要做好DBA,就要更好地理解数据库设计范式.数据库范式总结概览: 为了更好地理解数据库的设计范式,这里借用一下知乎刘慰老师的解释,很通俗易懂.非常感谢!   二.具体说明: 首先要明白”范 ...

  2. mysql中数据库database、实例instance、会话session的关系

    1. No suitable driver found for http://127.0.0.1:3306/test jdbc_url错误,jdbc走自己的协议. 正确的路径应该是:jdbc:mysq ...

  3. 用命令查看Mysql中数据库、表的空间大小

    要想知道每个数据库的大小的话,步骤如下:1.进入information_schema 数据库(存放了其他的数据库的信息)use information_schema;2.查询所有数据的大小:selec ...

  4. 修改mysql中数据库存储主路径

    一.首先把mysql的服务先停掉. 二.更改MySQL配置文件My.ini中的数据库存储主路径 打开文件夹C:\ProgramData\MySQL\MySQL Server 5.7中的my.ini文件 ...

  5. mysql中数据库与数据表编码格式的查看、创建及修改

    一.查看数据库编码格式 ? 1 mysql> show variables like 'character_set_database'; 二.查看数据表的编码格式 ? 1 mysql> s ...

  6. 使用sql对比Mysql中数据库2个表结构

    比较两个数据表的结构 SELECT column_name, max( CASE WHEN table_name = 'table1' AND table_schema = 'db1' THEN 'Y ...

  7. MySQL中一些关于索引的知识点

    什么是索引 索引是一种数据结构,其作用就是用来提高数据查询效率.比较常用的比喻就是将其类比为书籍的目录.通过目录可以精确的找到某一章节的内容所在页. 在数据量较小的时候使用索引其实也没有什么意义,即使 ...

  8. MySQL中Identifier Case Sensitivity

    在MySQL当中,有可能遇到表名大小写敏感的问题.其实这个跟平台(操作系统)有关,也跟系统变量lower_case_table_names有关系.下面总结一下,有兴趣可以查看官方文档"Ide ...

  9. mysql切换数据库提示警告:Reading table information for completion of table and column names

    登录数据库后,选择数据库时发现以下提示, mysql> use testReading table information for completion of table and column ...

随机推荐

  1. 饭卡-HDU2546(01背包)

    http://acm.hdu.edu.cn/showproblem.php?pid=2546 饭卡 Time Limit: 5000/1000 MS (Java/Others)    Memory L ...

  2. Spring Boot多数据源连接8小时后断开的问题解决(MySQL)

    这个问题涉及的方面很多,需要一步步去排查,可能环境有问题,数据库有问题,但是网上最多的应该是如下的方式去解决. 以单个数据源为主,多个数据源基本方法一致. 1.MySQL 5版本之前可以通过在URL后 ...

  3. Servlet实现页面重定向

    以下内容引用自http://wiki.jikexueyuan.com/project/servlet/page-redirect.html: 当文档移动到一个新的位置时,通常会使用页面重定向,需要将客 ...

  4. POJ 1384 POJ 1384 Piggy-Bank(全然背包)

    链接:http://poj.org/problem?id=1384 Piggy-Bank Time Limit: 1000MS Memory Limit: 10000K Total Submissio ...

  5. react 项目实战(三)表单验证

    我们需要记录每一个字段当前的有效状态,有效时隐藏错误信息,无效时显示错误信息. 而这个有效/无效,可以在表单值改变的时候进行判断. 我们对/src/pages/UserAdd.js进行修改: 首先修改 ...

  6. KLT 光流

    一 光流 光流的概念是Gibson在1950年首先提出来的.它是空间运动物体在观察成像平面上的像素运动的瞬时速度,是利用图像序列中像素在时间域上的变化以及相邻帧之间的相关性来找到上一帧跟当前帧之间存在 ...

  7. 【CERC2008】【BZOJ4319】Suffix reconstruction

    Description 话说练习后缀数组时,小C 刷遍 poj 后缀数组题. 各类字符串题闻之丧胆.就在准备对敌方武将发出连环杀时,对方一记无中生有,又一招顺 手牵羊.小C 程序中的原字符数组就被牵走 ...

  8. ibatis 入门

     iBatis 简单介绍: iBatis 是apache 的一个开源项目.一个O/R Mapping 解决方式,iBatis 最大的特点就是小巧.上手非常快.假设不须要太多复杂的功能.iBatis ...

  9. .NET中的PublicKeyToken以及强命名问题

    在.NET的GAC出现之前,以前有DLL Hell的问题.这是由于当时对于共享的DLL的处理方式.是通过採用注冊表的方式实现的.当我们安装一个程序A的时候,这个程序包括一个共享的DLL,那么这个DLL ...

  10. 关于ListView的setEmptyView没效果的问题

    使用listView或者gridView时,当列表为空时.有时须要显示一个特殊的empty view来提示用户,普通情况下,假设你是继承ListActivity.仅仅要 TextView tv= ne ...