ER图的最小化

问题陈述

ER图是显示各种表格及其之间关系的图形表示。 ER 图我们可以减少数据库数量

一对一基数

让我们考虑下面的一对一基数图 -

ER图的最小化

在此 ER 图中,员工可以为一家公司工作,但公司可以有许多这样的员工。上面的 ER 图代表 3 个实体 -

  • Employee 实体有 2 个属性,即 - emp_id 和 emp_name。 emp_id 是主键
  • 公司实体有 2 个属性,即 - emp_id 和 cmp_name。 cmp_id 是主键
  • 我们不能将 cmp_id 作为主键,因为多个员工可以为同一个 cmp_id 工作。但是,我们可以将 Employee 和 Work 表结合起来。因此,在一对多基数场景中至少需要 2 个表。

多对多基数

让我们考虑下图的一对多基数 -

ER图的最小化

在此 ER 图中,员工可以为多家公司工作 一个公司可以有很多这样的员工。上面的 ER 图代表 3 个实体 -

  • Employee 实体有 2 个属性,即 - emp_id 和 emp_name。 emp_id 是主键
  • 公司实体有 2 个属性,即 - emp_id 和 cmp_name。 cmp_id 是主键
  • 与前面的示例不同,无法将工作表与 Employee 或 Company 合并。如果我们尝试合并它,则会创建冗余数据。因此,在多对多基数场景中至少需要 2 个表

以上就是ER图的最小化的详细内容,更多请关注编程之家其它相关文章

相关文章

MySQL 死锁 是指两个或多个事务互相等待对方持有的锁,从而导...
在MySQL中,InnoDB引擎通过Next-Key Locking技术来解决幻读问...
在数据库事务管理中,Undo Log 和 Redo Log 是两种关键日志,...
case when概述 sql语句中的case语句与高级语言中的switch语句...
其实很简单,只是为了忘记,做个记录,用的时候方便。 不管是...
1.进入服务,找到mysql服务,在属性里找到mysql的安装路径 2...