当前位置: 首页 > 面试题库 >

数据库设计中的继承

穆招
2023-03-14
问题内容

我正在设计一个包含许多主要实体类型的新实验室数据库。

每个实体的表将包含该实体的所有类型(entity_id,created_on,created_by等)通用的字段。然后,我将使用具体继承(每个唯一的属性集使用单独的表)来存储所有剩余字段。

我相信这是每天通过实验室的标准数据类型的最佳设计。但是,我们经常有一个特殊的样本,这些样本通常伴随着原始者想要存储的特定值。

问题: 我应该如何为特殊(非标准)类型的实体建模?

选项1: 用于特殊领域使用的实体价值的
一个表(entity_idattribute_namenumerical_value)将持有的所有数据进行任何特殊的实体。
+较少的表格。
-无法强制要求特定属性。
-必须将行转换(枢轴)为无效的列。

选项2: 严格的具体继承。
为每个单独的特殊情况创建单独的表。
+遵循所有其他规则
-只有几行的许多表的开销。

选项3: 使用不同用户下的特殊表进行具体继承。
将所有特殊表放在另一个用户下。
+将所有特殊表和标准表分开。
+更容易在列表中搜索通用标准表,而无需搜索所有特殊表。
-只有几行的许多表的开销。


问题答案:

实际上,您描述的设计(公用表以及特定于子类型的表)称为“类表继承”。

具体表继承将在子类型表中重复所有通用属性,并且您将没有像现在这样的超类型表。

我强烈反对EAV。我认为它是SQL反模式。这似乎是一个不错的解决方案,因为它需要较少的表,但是稍后您会感到头疼。您确定了几个缺点,但还有许多其他缺点。恕我直言,仅当引入新的子类型时绝对
不能 创建新表,或者子类型数不受限制(例如,用户可以临时定义新属性)时,才正确使用EAV 。

您有很多子类型,但是它们仍然是有限的,所以如果我做这个项目,我会坚持使用 Class Table Inheritance
。每个子类型的行数可能很少,但是至少可以确保每个子类型的所有行都具有相同的列,可以NOT NULL根据需要使用,可以使用SQL数据类型,可以使用引用完整性约束,等等。从关系的角度来看,这是比EAV更好的设计。

您没有提到的另一个选项称为序列化LOB。也就是说,为自定义属性的半结构化集合添加BLOB列。在该列中存储XML,YAML,JSON或您自己的DSL。您将无法使用SQL轻松地从该BLOB中解析出各个属性,您将不得不将整个BLOB取回应用程序,并在代码中提取出各个属性。因此在某些方面不太方便。但是,如果这满足您对数据的使用,那么这没什么问题。



 类似资料:
  • 问题内容: 有什么方法可以在数据库中使用继承(特别是在SQL Server 2005中)? 假设我想在所有实体上添加诸如 CreatedOn , CreatedBy之 类的字段。我正在寻找一种替代方法,而不是将这些字段添加到每个表中。 问题答案: 在SQL Server 2005中,表之间没有继承之类的东西,并且正如其他人所指出的那样,在创建表时,您可以获得最大的帮助,将必要的列添加到表中,但不会

  • 我计划将一个整体ASP. Net MVC应用程序迁移到微服务架构。 该应用程序位于教育领域,下面是当前拥有的子模块, 系统管理员 研究所管理员 候选人/学生门户 辅导员/教师门户 课程设置(可由辅导员或学院管理人员完成) 考试门户 报告门户[新] 视频会议门户[新] 为了实现微服务架构,我打破了当前的系统,如下图所示,并为每个模块创建DB。 在这里我面临一个问题,比如说考试 Db 目前与课程和科目

  • 需求描述 有一个项目,面向学校德育评价,打算留一个发布通知的模块,现在拿不准如何设计数据库 个人方案 我个人有预想两种方案去解决 在mysql中建一个系统通知表 直接存redis中 第一种方案的优点是可以实现数据的持久化,但是对于一些时效性较强的通知【例如系统维护通知等】需要进行额外处理【因为基本上过了时效以后这条记录几乎不会再用到了】 第二种方案的优点是可以比较轻松的处理时效性问题,但是需要考虑

  • 1、数据库设计最起码要占用这个项目开发的40%以上的时间 2、数据库设计不仅仅停留在页面demo的表面 页面内容所需字段,在数据库设计中只是一部分,还有系统运转、模块交互、中转数据、表之间的联系等等所需要的字段,因此数据库设计绝对不是简单的基本数据存储,还有逻辑数据存储。 3、数据库设计完成后,项目80%的设计开发都要存在你的脑海中 每个字段的设计都要有他存在的意义,要清楚的知道程序中如何去运用这

  • 在《数据库设计概述》一节,我们讲解了为什么需要设计数据库。本节主要介绍数据库设计的基本步骤。 在了解数据库设计步骤之前,我们先来了解一下软件项目的开发周期,如下: 需求分析 概要设计 逻辑设计/详细设计 代码编写 软件测试 安装部署 其中,项目开始的第一步都是根据客户需求去设计数据库。代码编写阶段就是根据选择的数据库进行物理实现,编写代码实现应用。 按照规范设计的方法,考虑数据库及其应用系统开发全

  • 数据库设计就是根据业务系统的具体需求,结合我们所选用的数据库,建立好表结构及表与表之间的管理关系,为这个业务系统构造出最优秀的数据存储模型的过程。使之能有效的对应用的数据进行存储,并高效的对已经存储的数据进行访问。 数据库设计是数据库系统中的重要组成部分。一个良好的数据库可以给系统带来清晰的数据统计与数据的详细分析,给系统带来方便直观的数据。不良的数据库设计,必然会造成很多问题,轻则增减字段,重则