当前位置: 首页 > news >正文

【数据库设计和SQL基础语法】--数据库设计基础--数据建模与ER图

一、数据建模的基本概念

1.1. 数据模型的概念

数据模型是对现实世界中事物及其之间关系的一种抽象表示。它提供了描述数据结构、数据操作、数据约束等的方式,是数据库设计的基础。数据模型帮助我们理解数据之间的关系,提供了一种规范化的方式来组织和存储数据。

1.2. 主要类型:
  1. 概念模型(Conceptual Model)
    概念模型描述的是业务规则和数据的高层抽象,它不关心数据的具体存储细节。概念模型通常用实体-关系图(ER图)表示,其中实体表示数据对象,关系表示实体之间的关联。

  2. 逻辑模型(Logical Model)
    逻辑模型定义了数据库中数据的结构,包括表、字段和关系。它是概念模型的具体化,考虑了数据的实际存储和操作方式。关系数据库中的数据模型属于逻辑模型,通过表、关系和约束来表示数据。

  3. 物理模型(Physical Model)
    物理模型描述数据在计算机存储中的实际存储方式。它考虑了存储引擎、索引、分区等实际数据库管理系统的细节。物理模型的设计影响数据库的性能和存储效率。

数据模型是数据库设计的基石,通过不同层次的模型(概念、逻辑、物理),它提供了一种有序且抽象的方式来理解和组织数据。概念模型关注业务规则,逻辑模型定义数据结构,物理模型考虑实际存储和性能优化。这三种模型相互关联,构建了数据库系统的全貌。

二、数据建模与ER图

2.1 ER图的定义和作用
  1. 定义
    实体-关系图(ER图)是一种图形化工具,用于表示数据库中的实体、关系和属性之间的关联。它是概念模型的一种表达方式,采用图形化的方式展示系统中的数据结构,包括实体(Entity)、关系(Relationship)、属性(Attribute)等元素。

  2. 主要元素

    • 实体(Entity): 表示数据库中的对象或事物,通常用矩形表示,矩形内写有实体的名称。
    • 关系(Relationship): 表示实体之间的联系,通常用菱形表示,连接实体的线上标明关系的名称。
    • 属性(Attribute): 表示实体或关系的特征或属性,通常用椭圆形表示,连接实体或关系的线上标明属性的名称。
  3. 作用:

    • 可视化数据模型: ER图提供了一种直观、可视化的方式,帮助数据库设计者和利益相关者理解数据之间的关系和结构。
    • 规范化设计: 通过ER图,设计者可以识别和规范化数据结构,确保数据库设计符合规范化原则,减少数据冗余和提高一致性。
    • 需求分析: ER图有助于从用户和业务角度理解系统的需求,帮助设计者捕捉和分析系统中的实体、属性和关系。
    • 通信工具: ER图不仅是设计者之间的工具,也是与非技术人员(如业务分析师、项目经理)进行沟通的有效手段,促进团队合作。
    • 设计验证: ER图可以用于验证设计的准确性,与用户讨论图形化的表示,确保设计与业务需求一致。
    • 数据库实施: 在数据库实施阶段,ER图为物理数据库的创建提供了指导,有助于将概念模型转化为具体的数据库结构。

实体-关系图是数据库设计中的重要工具,通过图形化的方式展示实体、关系和属性之间的关系,为数据库设计、需求分析和沟通提供了有力的支持。ER图在整个数据库生命周期中都具有关键作用,是数据库设计不可或缺的一部分。

2.2 ER图的基本元素
  1. 实体
    实体是实体-关系图(ER图)中的一个基本元素,用于表示数据库中的对象或事物。实体代表系统中具有独立身份的概念,可以是现实世界中的一个物体、概念或事件。在ER图中,实体通常由一个矩形表示,矩形内包含实体的名称。

    • 主要特征和概念

      1. 独立身份: 实体具有独立的身份,可以被识别和区分。每个实体在数据库中有唯一的标识符,称为主键。
      2. 属性: 实体可以有相关的属性,描述实体的特征或属性。属性通常用椭圆形表示,连接到实体的线上标明属性的名称。
      3. 例子: 在一个学生信息系统中,"学生"可以是一个实体,它具有属性如学号、姓名、年龄等。每个学生实体都有唯一的学号作为主键。
    • 在ER图中的表示

      1. 使用一个矩形表示实体,矩形内写有实体的名称。
      2. 通常,实体名称使用大驼峰式命名,以清晰表示实体的概念。
  2. 关系
    关系是实体-关系图(ER图)中的一个基本元素,用于表示数据库中实体之间的关联。关系描述了一个或多个实体之间的联系和互动。在ER图中,关系通常由一个菱形表示,连接相关联的实体,关系的线上标有关系的名称。

    • 主要特征和概念

      1. 连接实体: 关系通过连接相关联的实体,表示这些实体之间有某种关联。
      2. 角色: 在关系中,每个实体都扮演一个角色,描述实体在关系中的作用。
      3. 度: 关系的度表示参与关系的实体的数量,可以是二元关系(二元组)或更高度的关系。
      4. 例子: 在学生信息系统中,"选修"可以是一个关系,连接"学生"和"课程"两个实体,表示学生选择了某门课程。
    • 在ER图中的表示

      1. 使用一个菱形表示关系,连接相关联的实体。关系的线上标有关系的名称。
      2. 如果关系具有角色,可以在关系线上标明角色的名称。
  3. 属性
    属性是实体-关系图(ER图)中的一个基本元素,用于描述实体或关系的特征或属性。属性为我们提供关于实体或关系更多细节的信息。在ER图中,属性通常由椭圆形表示,连接到相应的实体或关系的线上,并标有属性的名称。

    • 主要特征和概念

      1. 特征描述: 属性用于描述实体的特征,如实体的属性描述学生的姓名、年龄等。
      2. 标识符: 属性通常作为实体或关系的标识符,用于唯一地标识实体或关系。
      3. 数据类型: 属性具有数据类型,例如字符串、整数、日期等,定义了属性可以存储的值的类型。
      4. 复合属性: 属性可以是单一的,也可以是由多个子属性组成的复合属性,用于表示更复杂的信息。
    • 在ER图中的表示

      1. 使用椭圆形表示属性,连接到相应的实体或关系的线上。属性的线上标有属性的名称。
      2. 数据类型通常以括号的形式标记在属性名称的后面,以表示属性可以存储的数据类型。
2.3 ER图的绘制步骤

绘制实体-关系图(ER图)是数据库设计过程中的重要步骤,以下是一般的绘制步骤:

  1. 确定实体: 确定系统中存在哪些实体,这些实体可以是具体的对象、事件、概念等。
  2. 确定关系: 确定实体之间的关系,考虑它们是如何相互关联的。关系可以是一对一、一对多或多对多的。
  3. 确定属性: 为每个实体和关系确定相应的属性。属性是描述实体特征的,也可以用来说明关系的特性。
  4. 确定主键: 对于每个实体和关系,确定主键。主键是能够唯一标识实体或关系的属性。
  5. 确定关系的度: 对于关系,确定它的度数,即关联实体的数量。关系可以是二元关系、三元关系等。
  6. 为实体和关系选择适当的符号: 使用符号(矩形表示实体、菱形表示关系、椭圆形表示属性)来绘制实体、关系和属性。
  7. 标记实体和关系的名称: 在相应的符号上标记实体和关系的名称,使得图形更易读。
  8. 为关系标记角色和基数: 如果关系有角色,标记每个实体在关系中的角色。同时,标记关系的基数,表示参与关系的实体的数量。
  9. 添加注释和约束: 在需要时,添加注释和约束,以更清晰地说明实体-关系图的意义和规则。
  10. 审查和验证: 审查绘制的ER图,确保它符合数据库设计的需求。验证图形是否准确地反映了系统中的实体、关系和属性。
  11. 整理图形: 保持图形整洁有序,可以使用适当的布局工具整理ER图。
  12. 文档化: 将ER图文档化,包括实体、关系、属性、主键、外键等信息,并确保文档是最新的。
  13. 版本控制: 为绘制的ER图和文档实施版本控制,以便追溯设计的变更。

以上步骤是通用的绘制ER图的指导,具体细节可能会根据项目的特定需求和设计规范有所调整。

三、总结

数据建模是数据库设计的基础,通过概念、逻辑和物理三个层次的模型,提供了有序且抽象的方式来理解和组织数据。ER图作为重要的可视化工具,定义了实体、关系和属性的表示方式,有助于可视化数据模型、规范化设计、需求分析和设计验证。实体、关系和属性是ER图的基本元素,通过符号清晰表示,构建了数据库系统的全貌。ER图的绘制步骤包括确定实体、关系、属性,选择符号,标记名称和角色,最终通过审查验证、整理图形和文档化等步骤完成设计。

相关文章:

【数据库设计和SQL基础语法】--数据库设计基础--数据建模与ER图

一、数据建模的基本概念 1.1. 数据模型的概念 数据模型是对现实世界中事物及其之间关系的一种抽象表示。它提供了描述数据结构、数据操作、数据约束等的方式,是数据库设计的基础。数据模型帮助我们理解数据之间的关系,提供了一种规范化的方式来组织和存…...

Vue3 设置点击后滚动条移动到固定的位置

需求&#xff1a; 点击不通过按钮&#xff0c;显示红框中表单&#xff0c;且滚动条滚动到底部 &#xff08;显示红框中表单默认不显示&#xff09; <el-button click"onApprovalPass">不通过</el-button> <div class"item" v-if"app…...

外部 prometheus监控k8s集群资源(pod、CPU、service、namespace、deployment等)

prometheus监控k8s集群资源 一&#xff0c;通过CADvisior 监控pod的资源状态1.1 授权外边用户可以访问prometheus接口。1.2 获取token保存1.3 配置prometheus.yml 启动并查看状态1.4 Grafana 导入仪表盘 二&#xff0c;通过kube-state-metrics 监控k8s资源状态2.1 部署 kube-st…...

LLMLingua:集成LlamaIndex,对提示进行压缩,提供大语言模型的高效推理

大型语言模型(llm)的出现刺激了多个领域的创新。但是在思维链(CoT)提示和情境学习(ICL)等策略的驱动下&#xff0c;提示的复杂性不断增加&#xff0c;这给计算带来了挑战。这些冗长的提示需要大量的资源来进行推理&#xff0c;因此需要高效的解决方案&#xff0c;本文将介绍LLM…...

数据资产确权的难点

数据是企业的重要资产之一&#xff0c;但是许多企业对于这项资产在管理上都面临着一些挑战&#xff0c;其中最关键就是数据确权的问题。接下来&#xff0c;将探讨数据资产确权的难点&#xff0c;并提出相应的解决方案&#xff0c;一起来看吧。 首先介绍一下数据资产入表的背景以…...

EMG肌肉电信号处理合集(二)

本文主要展示常见的肌电信号特征的提取说明。使用python 环境下的Pysiology计算库。 目录 1 肌电信号第一次burst的振幅&#xff0c; getAFP 函数 2 肌电信号波长的标准差计算&#xff0c;getDASDV函数 3 肌电信号功率谱频率比例&#xff0c;getFR函数 4 肌电信号直方图…...

2023亚马逊云科技re:Invent引领科技新潮流:云计算与生成式AI共塑未来

2023亚马逊云科技re:Invent引领科技新潮流&#xff1a;云计算与生成式AI共塑未来 历年来&#xff0c;亚马逊云科技re:Invent&#xff0c;不仅是全球云计算从业者的年度狂欢&#xff0c;更是全球云计算领域每年创新发布的关键节点。 2023年亚马逊云科技re:Invent大会在美国拉斯…...

案例018:基于微信小程序的实习记录系统

文末获取源码 开发语言&#xff1a;Java 框架&#xff1a;SSM JDK版本&#xff1a;JDK1.8 数据库&#xff1a;mysql 5.7 开发软件&#xff1a;eclipse/myeclipse/idea Maven包&#xff1a;Maven3.5.4 小程序框架&#xff1a;uniapp 小程序开发软件&#xff1a;HBuilder X 小程序…...

视频剪辑技巧:如何高效批量转码MP4视频为MOV格式

在视频剪辑的过程中&#xff0c;经常会遇到将MP4视频转码为MOV格式的情况。这不仅可以更好地编辑视频&#xff0c;还可以提升视频的播放质量和兼容性。对于大量视频文件的转码操作&#xff0c;如何高效地完成批量转码呢&#xff1f;现在一起来看看云炫AI智剪如何智能转码&#…...

node.js获取unsplash图片

1. 在Unsplash的开发者页面注册并创建一个应用程序&#xff0c;以便获取一个API访问密钥&#xff08;即Access Key&#xff09;。 2. 安装axios&#xff1a; npm install axios3. 使用获取到的API密钥进行请求。 示例代码如下&#xff1a; const axios require(axios);con…...

Git远程库操作(GitHub)

GitHub 网址&#xff1a;https://github.com/ 创建远程仓库 远程仓库操作 命令名称作用git remote -v查看当前所有远程地址别名git remote add 别名 远程地址起别名git push 别名 分支推送本地分支上的内容到远程仓库git clone 远程地址将远程仓库的内容克隆到本地git pull 别…...

java计算下一个整10分钟时间点

最近工作上遇到需要固定在整10分钟一个周期调度某个任务&#xff0c;所以需要这样一个功能&#xff0c;记录下 package org.example;import com.google.gson.Gson; import org.apache.commons.lang3.time.DateUtils;import java.io.InputStream; import java.util.Calendar; i…...

力扣刷题篇之排序算法

系列文章目录 前言 本系列是个人力扣刷题汇总&#xff0c;本文是排序算法。刷题顺序按照[力扣刷题攻略] Re&#xff1a;从零开始的力扣刷题生活 - 力扣&#xff08;LeetCode&#xff09; 这个之前写的左神的课程笔记里也有&#xff1a; 左程云算法与数据结构代码汇总之排序&am…...

一键填充字幕——Arctime pro

之前的博客中&#xff0c;我们聊到了PR这款专业的视频制作软件&#xff0c;但是pr有许多的功能需要搭配使用&#xff0c;相信不少小伙伴在剪辑视频时会发现一个致命的问题&#xff0c;就是字幕编写。伴随着人们对字幕需求的逐渐增加&#xff0c;这款软件便应运而生~ 相信应该有…...

间隔分区表(DM8:达梦数据库)

DM8:达梦数据库 - 间隔分区表 环境介绍1 按 年 - 间隔分区表2 按 月 - 间隔分区3 按 日 - 间隔分区4 按 数值 - 间隔分区表5 达梦数据库学习使用列表 环境介绍 间隔分区表使用说明&#xff1a; 仅支持一级范围分区创建间隔分区。 只能有一个分区列&#xff0c;且分区列类型为…...

基于C#实现并查集

一、场景 有时候我们会遇到这样的场景&#xff0c;比如:M{1,4,6,8},N{2,4,5,7}&#xff0c;我的需求就是判断{1,2}是否属于同一个集合&#xff0c;当然实现方法有很多&#xff0c;一般情况下&#xff0c;普通青年会做出 O(MN)的复杂度&#xff0c;那么有没有更轻量级的复杂度呢…...

opencv-图像轮廓

轮廓可以简单认为成将连续的点&#xff08;连着边界&#xff09;连在一起的曲线&#xff0c;具有相同的颜色或者灰度。轮廓在形状分析和物体的检测和识别中很有用。 • 为了更加准确&#xff0c;要使用二值化图像。在寻找轮廓之前&#xff0c;要进行阈值化处理或者 Canny 边界检…...

小黑子—Maven高级

Maven高级篇 二 小黑子的Maven高级篇学习1. 分模块开发1.1 分模块开发设计1.2 分模块开发实现1.2.1 抽取domain层1.2.2 抽取dao层 2. 依赖管理2.1 依赖传递2.2 可选依赖2.3 排除依赖 3. 继承与聚合3.1 聚合3.2 继承3.3 总结 4. 属性4.1 配置文件加载属性4.2 版本管理 5. 多环境…...

一个正整数转为2进制和8进制,1的个数相同的第23个数是什么?

package cn.com;import java.lang.*;//默认加载public class C2 {//10进制转8进制static int HtoO(int n){int cnt 0;while(n!0){cntn%8;n/8;}return cnt;}//10进制转2进制static int HtoB(int n){int cnt 0;while(n!0){cntn%2;n/2;}return cnt;}public static void main(Str…...

Unity阻止射线穿透UI的方法之一

if(UnityEngine.EventSystems.EventSystem.current.IsPointerOverGameObject()) return; 作者&#xff1a;StormerZ https://www.bilibili.com/read/cv27797873/ 出处&#xff1a;bilibili...

三步搞定阿里云三要素校验:从零封装一个安全高效的Java工具类

1. 为什么需要封装三要素校验工具类 在金融支付、电商实名认证等业务场景中&#xff0c;三要素校验&#xff08;姓名身份证号手机号&#xff09;是最基础的安全防线。但每次直接调用阿里云原生接口会遇到几个典型问题&#xff1a; 第一是参数处理繁琐。比如手机号加密要自己实…...

Davinci Configurator实战:利用Supplier Notification机制为你的UDS诊断服务加一把“安全锁”

Davinci Configurator实战&#xff1a;利用Supplier Notification机制构建UDS诊断安全防线 当ECU诊断服务暴露在复杂的车载网络环境中时&#xff0c;未经授权的访问就像未受监控的港口入口&#xff0c;随时可能引发系统性风险。传统DCM模块的标准校验逻辑往往难以应对灵活多变的…...

别再死记硬背了!手把手教你标定三相霍尔传感器与电机电角度的映射关系

三相霍尔传感器与电机电角度标定实战指南 在无刷直流电机&#xff08;BLDC&#xff09;和磁场定向控制&#xff08;FOC&#xff09;系统中&#xff0c;精确获取转子位置是实现高效控制的基础。霍尔传感器作为最常用的位置检测元件&#xff0c;其状态与电角度的映射关系直接决定…...

手把手教你搞定海洋磁测:从拖鱼定深到日变站布设的全流程实战

海洋磁测实战指南&#xff1a;从拖鱼定深到日变站布设的全流程解析 清晨六点&#xff0c;当第一缕阳光洒在甲板上&#xff0c;测量船已经驶离港口三十海里。作为本次磁力测量任务的首席操作员&#xff0c;我打开设备箱检查G-882磁力仪的探头状态——这已经是今年第三次执行近岸…...

假期机器学习实战书单:从入门到精通的指南

1. 假期机器学习书单&#xff1a;从入门到精通的实战指南又到了年末假期季&#xff0c;对于技术人来说&#xff0c;这段时间最适合静下心来系统学习新技能。作为从业多年的机器学习工程师&#xff0c;我每年都会收到大量关于"如何选择机器学习书籍"的咨询。不同于市面…...

从GLUT到GLFW:我的OpenGL开发环境搭建史与踩坑记录

从GLUT到GLFW&#xff1a;我的OpenGL开发环境搭建史与踩坑记录 第一次接触OpenGL是在大学计算机图形学课程上。教授发来的示例代码里赫然写着#include <GL/glut.h>&#xff0c;当时只觉得这个库名字有点奇怪——谁会用一个叫"胶水"的库呢&#xff1f;但真正让我…...

3分钟搞定20+输入法词库转换:深蓝词库转换工具终极指南

3分钟搞定20输入法词库转换&#xff1a;深蓝词库转换工具终极指南 【免费下载链接】imewlconverter ”深蓝词库转换“ 一款开源免费的输入法词库转换程序 项目地址: https://gitcode.com/gh_mirrors/im/imewlconverter 你是否曾因为更换电脑或输入法而丢失了多年积累的个…...

终极指南:三步解锁QQ音乐加密文件,让音乐真正属于你

终极指南&#xff1a;三步解锁QQ音乐加密文件&#xff0c;让音乐真正属于你 【免费下载链接】QMCDecode QQ音乐QMC格式转换为普通格式(qmcflac转flac&#xff0c;qmc0,qmc3转mp3, mflac,mflac0等转flac)&#xff0c;仅支持macOS&#xff0c;可自动识别到QQ音乐下载目录&#xf…...

XUnity.AutoTranslator终极指南:快速实现Unity游戏多语言翻译

XUnity.AutoTranslator终极指南&#xff1a;快速实现Unity游戏多语言翻译 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 你是否因为语言障碍而错过了许多精彩的Unity游戏&#xff1f;XUnity.AutoTransla…...

Python3 模块精讲:StringIO —— 内存字符串 IO 全解与实战

文章标签&#xff1a;#Python #后端开发 #数据处理 #IO 操作 #StringIO 一、引言&#xff1a;为什么 StringIO 是 Python 内存 IO 必备核心 在 Python 数据处理、文件模拟、日志捕获、接口测试等场景中&#xff0c;StringIO 早已成为轻量高效、开箱即用的内存级字符串操作工具…...