如果我在 ERD 中表示 JSON 模型是不是有效?

Posted

技术标签:

【中文标题】如果我在 ERD 中表示 JSON 模型是不是有效?【英文标题】:Is it valid if I represent JSON model in ERD?如果我在 ERD 中表示 JSON 模型是否有效? 【发布时间】:2016-04-19 20:23:01 【问题描述】:

answer 声明:

另一边的ERD图,是一个持久化特定图 显示存在于中的实体(表格)(最常见) 关系数据库。

Q1:我很好奇,因为我很少看到 JSON 在 ERD 中表示。背后的原因是什么?

Q2:由于 JSON 不是关系数据模型,如果我使用 ERD 在 ERD 中表示我的 JSON 模型是否有效?

谢谢!

【问题讨论】:

【参考方案1】:

JSON 是一种分层数据结构的表示法,由标量值、数组和对象组成,可以嵌套到任意深度。任何层次结构都对其组件值之间的一种特定关系(包含)具有固有的偏好。其他关系可以表示,但支持很差 - 必须手动取消引用查找值,并且可以使用引用而不是查找值,但是由于被引用对象必须在引用对象之前存在,因此必须按程序构造数据,这意味着它不能用像 JSON 这样的声明性符号表示。分层数据结构的另一个弱点是实体身份通常是隐藏的。

相比之下,关系模型(以及实体关系模型,它只是对前者的一种细化解释)使身份明确,并且可以处理值之间的任意数量的关系,而不会偏袒一个而损害其余的。

javascript 数据通常可以分解为关系结构,通过识别每个记录/对象的类型并识别或引入每种类型的标识符,然后在规范化之前识别功能依赖关系。此时可以使用 ERD 来描述关系结构,但正如您所见,需要将分层数据转换为一组表。

【讨论】:

以上是关于如果我在 ERD 中表示 JSON 模型是不是有效?的主要内容,如果未能解决你的问题,请参考以下文章

如何在 ERD 中表示多对多关系

使用 circe 时如何在 Scala 中表示动态 JSON 键

如何在 thymeleaf 模板中表示 2 个模型对象

如何在 ember-data 模型中表示数组?

在图表中表示重复值

如果它们来自数据源,如何在 graphql 模式中表示枚举?