SQL数据库设计(一)---需求分析与逻辑设计

article/2025/9/12 4:39:30

今天先来介绍 数据库设计中的需求分析和逻辑设计(ER图)阶段,明天介绍物理设计与维护优化,数据库设计是非常有意思的:-)

数据库设计

根据系统业务的需要,结合我们所选用的DBMS,为这个业务系统构建出最优的数据存储模型。
并建立好数据库中的表结构,以及表与表之间的关联关系的过程.使之能有效的对应用系统中的数据进行存储,
并可以高效的对已经存储的数据进行访问.

优良的数据库设计

  • 减少数据冗余
  • 避免数据维护异常
  • 节约存储空间
  • 高效的访问

需求分析

分析数据和属性各自的特点

  1. 了解系统中所要存储的数据
  2. 了解数据的存储特点
  3. 了解数据的存储周期

需求分析中需要了解的问题

  1. 实体之间的关系
  2. 实体包含的属性是什么
  3. 那些属性或属性的组合可以唯一标示一个实体

电商网站数据模块的分解

模块属性可选唯一标识属性存储特点
用户模块用户名,密码,电话,邮箱,身份证号,地址,姓名等用户名,身份证号,电话随上线时间增加,需要永久存储
商品模块商品编码,商品名称,商品描述,商品品类,供应商名称,重量,有效期,价格等(商品名称,供应商名称),商品编码对于下线商品可以归档存储
订单模块订单号,用户姓名,用户电话,收货地址,商品编号,商品名称,数量,价格,订单状态,支付状态,订单类型订单号永久存储(分表,分库存储)
购物车模块用户名,商品编号,商品名称,商品和价格,商品描述,商品分类,加入时间,商品数量(用户名,商品编号,加入时间),购物车编号不用永久存储(设置归档,清理规则)
供应商模块供应商编号,供应商名称,联系人,电话营业执照号,地址,法人供应商编号,营业执照号永久存储

逻辑设计

ER图:逻辑模型得到展示方式
使用ER图对数据库进行逻辑建模,与DBMS无关。

ER图的图形含义

这里写图片描述

电商网站数据模块ER图

这里写图片描述

逻辑设计名词解释

这里写图片描述
不满足三个范式的设计的数据库会出现操作异常及数据冗余
操作异常
这里写图片描述
数据冗余:相同的数据在多个地方得到,或者说表中的某个列可以由其他列计算得到。

第一范式(1NF)

数据库表中所有字段都是单一属性的,不可再分的,这些单一属性使用基本的数据结构构成的.
第一范式要求数据库中所有的表都是二维表.

第二范式(2NF)

数据库中的表不存在非关键字段对任意候选关键的字段的部分函数依赖.
部分函数依赖指存在组合关键字中某一关键字决定非关键字的情况.
所有单关键字段的表都符合第二范式

不满足第二范式的示例
这里写图片描述

解决不满足第二范式造成的操作异常问题

这里写图片描述

第三范式(3NF)

第三范式是建立在第二范式的基础上的
如果数据库表不存在非关键字段对任意候选关键字段的传递函数依赖则符合第三范式

不满足第三范式的示例
这里写图片描述
解决不满足第三范式造成的操作异常
这里写图片描述

BC范式(BCNF)

在第三范式的基础上,数据库表中如果不存在任何字段对任意候选关键字段的传递函数依赖则符合BC范式
如果是复合关键字,则复合关键字之间也不能存在函数依赖关系.

这里写图片描述

参考资料
http://www.2cto.com/database/201409/331105.html


http://chatgpt.dhexx.cn/article/Z0iMAnA2.shtml

相关文章

数据库设计2————需求分析

需求分析任务 1、信息需求。明确数据库需要存储的数据,对这些数据将哪些梳理,同时还要描述数据间的联系。 2、处理需求。定义系统数据处理的操作功能,描述操作的优先次序。包括操作的执行频率和场合,操作与数据间的联系&#xff…

数据库设计(一) 需求分析

目前,大多数的应用系统都属于数据库应用程序,都离不开数据库的支持。数据库设计方案的优劣对于应用程序的运行至关重要。数据库设计过程就是针对具体的应用环境,设计优化的逻辑模式,并根据所采用的数据库系统设计物理结构&#xf…

三、数据需求与数据库设计

数据需求与数据库设计 数据需求 项目中主要包含了用户、权限(菜单)、角色三种类型的数据,各种数据包含的数据项如下: (1)用户:用户名、密码、生日、头像、简介、用户类型 (2&…

SQL数据库实战需求分析→数据库设计

从这开始,就真正进入项目实战啦。先说点体会,我刚开始接触编程的时候,都是编写一些小东西,往往都是半天或者一天什么的就编完了,那时候根本没想过做程序之前还要有需求分析。经过快两年的学习,接触的都是比…

数据库性能需求分析及评估模型

数据库作为应用系统当中最重要的一块,也是性能测试非常关注的一块,根据我自己的项目经验,和以往对应用系统的性能需求分析和测试策略制定过程,总结一下如何开展数据库系统的性能需求分析,以及制定数据库能力评估模型。…

互联网应用开发实践:需求分析与数据库设计

在本文中将分析一个用于新生开学分配寝室的“宿舍秒杀”系统。从用户故事开始探索需求,进而分析得到系统的主要功能和非功能性需求。最后,根据需求分析设计数据库,数据库的设计原则是尽可能的方便之后的需求拓展和修改。 用户故事 用户故事一…

数据库应用系统的需求分析

一 需求分析的概念与意义 所谓的需求分析,就是对待开发系统要做什么,完成什么功能的全面描述 软件的一些特性使得需求的获取常常并不容易! 比如软件功能复杂,需求可变性,软件的不可见性 二 获取需求的方法 面谈实地…

数据库设计:需求分析

设计一个性能良好的数据库系统,明确应用环境对系统的要求是首要的和基本的。因此,应该把对用户需求的收集和分析作为数据库设计的第一步。 需求分析的主要任务是通过详细调查要处理的对象,包括某个组织、某个部门、某个企业的业务管理等&…

数据库设计 | 需求分析

一、需求分析要干一个什么样的事情? 通过详细调查现实世界要处理的对象(组织、部门、企业等), 充分了解原系统(手工系统或计算机系统)工作概况, 明确用户的各种需求,然后在此基础上确…

数据库设计之需求分析

需求分析简单地说就是分析用户的需求。根据分析是设计数据库的起点,需求分析结果是否准确反映用户的实际要求将直接影响到后面各阶段的设计,并影响到设计结果是否合理和实用。 1. 需求分析的任务 需求分析的任务是通过详细调查现实世界要处理的对象(组…

数据库技术-数据库需求分析、数据流概念

目录 需求分析 数据流 结构化分析案例-教材销购案例 例题讲解 每文一语 需求分析 1、需求分析的概念与意义 需求是指用户对软件的功能和性能的要求,就是用户希望软件能做什么事情,完成什么样的功能,达到什么性能。 需求分析是在计算机…

matlab gui 教学,新手入门教程(一)文本框和按钮的使用

matlab gui 教学,新手入门教程(一)文本框和按钮的使用 一、新建文件二、添加控件 一、新建文件 1、在MATLAB命令行中输入guide。 2、回车,进入GUI的界面,选择新建GUI–Blank GUI(Default)–浏览(自定义存储…

零基础入门MATLAB(一篇十分钟)

目录 一、复数 二、取整函数 三、无穷量(Inf)和非数值量(NaN) 四、逻辑类型 五、字符和字符串 六、函数句柄 七、结构体 八、数组类型 九、单元数组 十、map容器类型 参考《MATLAB R2020a 完全自学一本通》 一、复数 …

matlab如何使输出结果更美观(symdisp函数——pretty函数升级版)

matlab中有些计算结果比较长,直接查看有些困难,下面介绍pretty和symdisp函数优化输出结果,使结果更为直观。 演示示例1 有一个计算结果如下: >> f1f1 y^5 (- w - y0)*y^4 1800*y^3 (1498200*w - 1800*y0)*y^2 (3600*w…

Matlab中textscan函数用法

目录 语法 说明 示例 读取浮点数 读取不同类型的数据 删除字面文本 跳过每行的其余部分 指定分隔符和空值转换 指定要视为空或注释的文本 将重复的分隔符视为一个分隔符 指定重复的转换设定符并收集数值数据 读取或跳过引用文本和数值字段 读取外语日期 读取非默…

【MATLAB学习笔记01】【快速入门】初识MATLAB的界面和编辑脚本的基础知识

打开MATLAB后,建议各位新手,先随便按下各个按键,熟悉下总体的页面布局,并且对各个按键的功能有点印象,这样可以更容易上手。 主要功能区(下图用红色方框圈出来的位置): 命令行窗口…

零基础入门Matlab(一篇两个小时就能学完的入门博客)

目录 零基础入门matlab前言1.界面认识2.变量命名3.数据类型4.元胞数组和结构体5.矩阵操作6.程序结构7.基本绘图操作7.1.二维平面绘图7.2.三维立体绘图 8.图形的保存与导出9.补充 零基础入门matlab 前言 这篇文章很适合MATLAB的入门学习,这也是我在入门时学习的笔记…

MATLAB中text函数使用

目录 语法 说明 示例 向数据点添加文本说明 向多个数据点添加文本 显示多行文本 指定文本大小和颜色 修改现有文本 text函数的功能是向数据点添加文本说明。 语法 text(x,y,txt) text(x,y,z,txt) text(___,Name,Value) text(ax,___) t text(___) 说明 text(x,y,…

matlab中实现文字和数字和混输出excel

做一个小程序时,需要数据和文字混合输出到,直接构建这样的矩阵在matlab中行不通 于是有了下列的代码: %输出excel表格 excel_outpathF:\Work\paper_work\parallel_simulation\code\excel\test.xlsx;%输出路径 %构建表头 rtnxlswrite(excel_…