ER模型介绍

2024-09-02 07:44
文章标签 介绍 模型 er

本文主要是介绍ER模型介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

7.1.概述:

  • 1.ER模型也叫做实体关系模型,是用来描述现实生活中客观存在的事物、事物的属性,以及事物之间关系的一种数据模型。
  • 2.在开发基于数据库的信息系统的设计阶段,通常使用ER模型来描述信息需要和信息特性,帮助我们理清业务逻辑,从而设计出优秀的数据库

7.2.ER 模型包括那些要素?

ER模型中有三个要素:分别是实体、属性和关系

  • 1.实体:
    • 可以看做是数据对象,往往对应于现实生活中的真实存在的个体
    • 在 ER 模型中,用矩形来表示。实体分为两类,分别是强实体弱实体
    • 强实体是指不依赖于其他实体的实体;弱实体是指对另一个实体有很强的依赖关系的实体。
  • 2.属性
    • 则是指实体的特性。比如超市的地址、联系电话、员工数等。
    • 在 ER 模型中用椭圆形来表示
  • 3.关系
    • 则是指实体之间的联系
    • 比如超市把商品卖给顾客,就是一种超市与顾客之间的联系
    • 在 ER 模型中用菱形来表示

注意:实体和属性不容易区分。这里提供一个原则:我们要从系统整体的角度出发去看,可以独立存在的是实体,不可再分的是属性。也就是说,属性不能包含其他属性。


7.3.关系的类型:

在 ER 模型的 3 个要素中,关系又可以分为 3 种类型,分别是 一对一、一对多、多对多

  • 1.一对一:指实体之间的关系是一一对应的
  • 2.一对多:指一边的实体通过关系,可以对应多个另外一边的实体。相反,另外一边的实体通过这个关系,则只能对应唯一的一边的实体
  • 3.多对多:指关系两边的实体都可以通过关系对应多个对方的实体

7.4.建模分析与建表:

a.概述:

  • 1.ER 模型看起来比较麻烦,但是对把控项目整体非常重要。如果你只是开发一个小应用,或许简单设计几个表够用了,一旦要设计有一定规模的应用,在项目的初始阶段,建立完整的 ER 模型就非常关键了。开发应用项目的实质,其实就是 建模

b.找出业务中的实体:

  • 2.这里设计的案例是尚品汇电商业务 ,由于电商业务太过庞大且复杂,所以我们做了业务简化,比如针对SKU(StockKeepingUnit,库存量位)和SPU(Standard Product Unit,标准化产品单元)的含义上,我们直接使用了SKU,并没有提及SPU的概念。本次电商业务设计总共有8个实体,如下所示。
    • 地址实体
    • 用户实体
    • 购物车实体
    • 评论实体
    • 商品实体
    • 商品分类实体
    • 订单实体
    • 订单详情实体
  • 3.其中, 用户商品分类是强实体,因为它们不需要依赖其他任何实体。而其他属于弱实体,因为它们虽然都可以独立存在,但是它们都依赖用户这个实体,因此都是弱实体。

c.根据实体关系建模:

  • 1.在分析出各个实体、强实体和弱实体这些要素后,我们就可以给电商业务创建 ER 模型了,如图:
    在这里插入图片描述
  • 2.在这个图中,我分析出了各个实体的关系,如地址和用户之间的添加关系,是一对多的关系,而商品和商品详情示一对1的关系,商品和订单是多对多的关系。 这个 ER 模型,包括了 8个实体之间的 8种关系
    • 用户可以在电商平台添加多个地址;
    • 用户只能拥有一个购物车;
    • 用户可以生成多个订单;
    • 用户可以发表多条评论;
    • 一件商品可以有多条评论;
    • 每一个商品分类包含多种商品;
    • 一个订单可以包含多个商品,一个商品可以在多个订单里。
    • 订单中又包含多个订单详情,因为一个订单中可能包含不同种类的商品

d.ER模型的细化

  • 1.有了这个 ER 模型,我们就可以从整体上 理解 电商的业务了。刚刚的 ER 模型展示了电商业务的框架,但是只包括了订单,地址,用户,购物车,评论,商品,商品分类和订单详情这八个实体,以及它们之间的关系,还不能对应到具体的表,以及表与表之间的关联。我们需要把 属性加上 ,用 椭圆 来表示,这样我们得到的 ER 模型就更加完整了。
  • 2.现在我进一步去设计一下这个 ER 模型的各个局部,也就是细化下电商的具体业务流程,然后把它们综合到一起,形成一个完整的 ER 模型。这样可以帮助我们理清数据库的设计思路。
  • 3.下面我再分析一下各个实体都有哪些属性,如下所示。
    • 地址实体 包括用户编号、省、市、地区、收件人、联系电话、是否是默认地址。
    • 用户实体 包括用户编号、用户名称、昵称、用户密码、手机号、邮箱、头像、用户级别。
    • 购物车实体 包括购物车编号、用户编号、商品编号、商品数量、图片文件url。
    • 订单实体 包括订单编号、收货人、收件人电话、总金额、用户编号、付款方式、送货地址、下单时间。
    • 订单详情实体 包括订单详情编号、订单编号、商品名称、商品编号、商品数量。
    • 商品实体 包括商品编号、价格、商品名称、分类编号、是否销售,规格、颜色。
    • 评论实体 包括评论id、评论内容、评论时间、用户编号、商品编号
    • 商品分类实体 包括类别编号、类别名称、父类别编号
  • 4.这样细分之后,我们就可以重新设计电商业务了,ER 模型如图:
    在这里插入图片描述

e.把ER模型图转换成数据表:

  • 1.通过绘制 ER 模型,我们已经理清了业务逻辑,现在我把绘制好的 ER模型,转换成具体的数据表,下面介绍下转换的原则
    • 一个 实体 通常转换成一个 数据表 ;
    • 一个 多对多的关系 ,通常也转换成一个 数据表
    • 一个 1 对 1 ,或者 1 对多 的关系,往往通过表的 外键 来表达,而不是设计一个新的数据表;
    • 属性转换成表的字段 。
  • 2.下面结合前面的ER模型,具体讲解一下怎么运用这些转换的原则,把 ER 模型转换成具体的数据表,从而把抽象出来的数据模型,落实到具体的数据库设计当中

强实体:用户表:

在这里插入图片描述

商品分类表:

  • 1.商品分类表可规划为2张表
    在这里插入图片描述
  • 2.商品分类表规划为一张表的问题:
    在这里插入图片描述

弱实体转为表:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.一个多对多的关系转换成一个数据库表:

在这里插入图片描述
在这里插入图片描述

3.通过外键来表达1对多的关系:

在这里插入图片描述

7.5.总结:

  • 1.其实,任何一个基于数据库的应用项目,都可以通过这种 先建立 ER 模型 ,再 转换成数据表 的方式,完成数据库的设计工作。
  • 2.创建 ER 目的是把业务逻辑梳理清楚,设计出优秀的数据库。我建议你不是为了建模而建模,要利用创建 ER 模的过程来整理思路,这样创建 ER 模型才有意义
    在这里插入图片描述

这篇关于ER模型介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1129393

相关文章

Golang的CSP模型简介(最新推荐)

《Golang的CSP模型简介(最新推荐)》Golang采用了CSP(CommunicatingSequentialProcesses,通信顺序进程)并发模型,通过goroutine和channe... 目录前言一、介绍1. 什么是 CSP 模型2. Goroutine3. Channel4. Channe

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

Python实现NLP的完整流程介绍

《Python实现NLP的完整流程介绍》这篇文章主要为大家详细介绍了Python实现NLP的完整流程,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 编程安装和导入必要的库2. 文本数据准备3. 文本预处理3.1 小写化3.2 分词(Tokenizatio

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了