数据库设计 ER图

数据库设计 ER图一、ER图简介ER图,简单来说,E是实体,实体有一组属性;R是关系。找打系统中的实体以及实体关系就可以绘制出ER图了。例如,下图是网上找到的ER图,矩形的是实体,椭圆是属性,实体何实体时间的关系用菱形,关系也有熟悉,例如,学生选修课程,有成绩属性,当然如果系统需要,也可以记录选修的时间等属性信息。认真看下,你会发现ER图理解起来还是比较容易的二、ER图绘制常见问题但是真的落实到自己绘制,很多同学就会遇到困难。下面我们通过反例来学习ER图1.反例1区分功能和关系.

大家好,又见面了,我是你们的朋友全栈君。

一、ER图简介

ER图,简单来说,E是实体,实体有一组属性;R是关系。找到系统中的实体以及实体关系就可以绘制出ER图了。

例如,下图是网上找到的ER图,矩形的是实体,椭圆是属性,实体和实体时间的关系用菱形,关系也有属性,例如,学生选修课程,有成绩属性,当然如果系统需要,也可以记录选修的时间等属性信息。

数据库设计 ER图

认真看下,你会发现ER图理解起来还是比较容易的。

ER图中识别出实体后,找到实体之间的关系很重要。而关系可能是一对一(1:1)、一对多(1:n),多对多(m:n),关系用菱形表示,而关系的类型在菱形的两条与实体的连接线上标注,

判断两个实体的关系是,先让实体A假设为1,看它能对应实体B的个数,然后反过来,假设实体B为1个,看实体A对应的个数,就可以得到实体对应关系。

例如,

1个学生关注多个商品,而1个商品被多个学生关注,所以学生和商品的关系是多对多

1个学生属于1个班级,而1个班级可以多个学生,所以班级和学生的关系是一对多

1个学生拥有1张饭卡,而1张饭卡属于1个学生。所以学生和饭卡的关系是一对一

数据库设计 ER图

二、ER图绘制常见问题

但是真的落实到自己绘制,很多同学就会遇到困难。下面我们通过反例来学习ER图

1.反例1  区分功能和关系

例如,管理员可以管理用户。但是如果系统不记录哪个管理员可以管理哪些用户,那么就无需在ER图上绘制该关系。只有需要在数据库保存的关系,才需要在ER图上保存。

2. 反例2:区分程序功能和数据库数据

挂号排队信息

我个人挂号排队一般不用保存到数据库,所以无需在ER图上表示

另外,如果要显示排队信息,我认为应当是给每个用户一个id序号,程序实现排队,而不是数据库去记录这个排队信息、

数据库设计 ER图

三。ER图转关系模式

数据库设计 ER图

 所有的实体应当转为一张表。所以上面的班级 学生 课程 教师都是一张表

班级表包含字段:班级号,班级名,专业,人数  主键:班级号

学生表包含字段:学号,姓名,性别,年龄 主键:学生号

课程表包含字段:课程号,课程名,课时,学分  主键:课程号

教师表包含字段:编号,姓名,职称,年龄,性别 主键:编号

根据关系是1:1  1:n   m:n 转成表

1)  对于 1:1的  可以将关系保存到任何一个实体表中,

2) 对于1:n的,可以将关系保存到n的那个实体里,例如图中的班级和学生是1对多,那么可以在学生表中增加一个班级id的字段,说明该学生是哪个班级的

学生表包含字段:学号,姓名,性别,年龄,班级ID 主键:学生号

3)对于多对多的关系  m:n的 ,关系保存到新表中

例如,学生和课程是多对多的关系,那么吧两个表的主键拿出来,加上关系属性,组成一个表

学生成绩表 学号 课程号 成绩  主键:学号  课程号

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/152026.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月21日 上午7:36
下一篇 2022年6月21日 上午7:36


相关推荐

  • Javascript注释规范

    Javascript注释规范Javascript注释规范

    2025年7月13日
    5
  • 【matlab】meshgrid的使用

    【matlab】meshgrid的使用函数参数列表[X,Y]=meshgrid(x,y)[X,Y]=meshgrid(x)[X,Y,Z]=meshgrid(x,y,z)[X,Y,Z]=meshgrid(x)meshgrid可以生成2D或者3D的矩阵,如果为2D,矩阵的shape为(y.length,x.length)如果为3D,矩阵的shape为(y.length,x.length,z.length)代码示例sample1x=1:2;%length2y=3:5;%length3[X,Y]=m

    2022年5月29日
    42
  • linux查看rsync的命令,Linux rsync 命令学习

    linux查看rsync的命令,Linux rsync 命令学习Rsync 命令和 cp 命令很像 但是功能似乎更加复杂点 主要用来备份数据 看了网上一堆介绍的文章 感觉不是很通俗易懂 下面按照我的理解 做一些笔记 同步方式之前接触过一些同步软件 例如坚果云 百度云盘等等 他们对于同步方式都是有一些选择项的 下面列举一些同步方式单向同步每次执行任务时 源目录中新建和更新的文件将被复制到目标目录中 目标目录中对应源目录中已经删除的文件 将被删除 此方式只是单向地对文件

    2026年3月26日
    2
  • 计算机网络放大器的作用,运算放大器

    计算机网络放大器的作用,运算放大器运算放大器(简称“运放”)是具有很高放大倍数的电路单元。在实际电路中,通常结合反馈网络共同组成某种功能模块。它是一种带有特殊耦合电路及反馈的放大器。其输出信号可以是输入信号加、减或微分、积分等数学运算的结果。由于早期应用于模拟计算机中用以实现数学运算,因而得名“运算放大器”。[1]由于早期应用于模拟计算机中,用以实现数学运算,故得名“运算放大器”。运放是一个从功能的角度命名的电路单元,可以由分立的…

    2022年5月22日
    33
  • vue漂亮的企业网站模板

    vue漂亮的企业网站模板vue 漂亮的企业网站模板公司最近更新一版网站 换成 vue 做的 静态模板 没有后台 pc 端已经自适用手机端 宣传够用了 废话少说 直接上图 拿去 部署步骤前期安装 nodejs vue 执行 npminstall gcnpmregistr https registry npm taobao orgcnpminsta 如果部署服务器出现 404 错误 修改处理 vue 部署 404 错误 server listen80 server

    2026年3月19日
    2
  • 使用SQL语句创建表(建立基本表数据的sql语句是)

    1.创建表的语法createtable表名(列1数据类型1,列2数据类型)tablespace表空间SQL:createtablestudent(IDNUMBERnotnull,NAMEVARCHAR2(20));表已创建…

    2022年4月18日
    278

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号