- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在调查Datomic ,看起来真的很有趣。不过好像有very good information on how Datomic works technically ,我还没有看到太多关于如何思考数据建模的内容。
Datomic 中数据建模的一些最佳实践是什么?有没有关于这个主题的好资源?
最佳答案
警告讲师
由于 Datomic 是新的,我对它的经验有限,因此无论如何不应将此答案视为最佳实践。对于那些具有关系背景并渴望更高效的数据存储的人,请将此作为 Datomic 的介绍。
入门
在 Datomic 中,您将域数据建模为拥有属性值的实体。因为对另一个实体的引用可以是属性的值,所以您可以简单地对实体之间的关系进行建模。
乍一看,这与在传统关系数据库中建模数据的方式并没有什么不同。在 SQL 中,表行是实体,表的列名是具有值的属性。关系由一个表行中的外键值表示,引用另一表行的主键值。
这种相似性很好,因为您可以在对域建模时勾勒出传统的 ER 图。您可以像在 SQL 数据库中一样依赖关系,但不需要弄乱外键,因为这是为您处理的。 Datomic 中的写入是事务性的,您的读取是一致的。因此,您可以以任何合适的粒度将数据分成实体,依靠连接来提供更大的图景。这是您在许多 NoSQL 存储中失去的便利,在这些存储中,通常使用大型非规范化实体来在更新期间实现某种有用的原子性级别。
在这一点上,您有了一个良好的开端。但是 Datomic 比 SQL 数据库灵活得多。
占优势
时间本质上是所有 Datomic 数据的一部分,因此无需特别将数据历史作为数据模型的一部分。这可能是 Datomic 中谈论最多的方面。
在 Datomic 中,您的架构并未严格按照 SQL 要求的“矩形形状”进行定义。即实体1可以拥有满足模型所需的任何属性。实体不需要 NULL
或不适用于它的属性的默认值。您可以根据需要向特定的单个实体添加属性。
因此,您可以随着时间的推移更改单个实体的形状,以响应域中的变化(或您对域的理解的变化)。所以呢?这与 MongoDB 和 CouchDB 等文档存储不同。
不同之处在于,使用 Datomic,您可以对所有受影响的实体以原子方式进行模式更改。这意味着您可以基于任意域逻辑发出一个事务来更新所有实体的形状,用您的语言写成 [2],这将在不影响读者的情况下执行,直到提交。我不知道在关系或文档存储空间中有任何接近这种权力的东西。
您的实体也没有严格定义为“生活在一张 table 上”。您决定什么定义了 Datomic 中实体的“类型”。您可以选择明确并强制要求模型中的每个实体都有一个 :table
表示它是什么“类型”的属性。或者您的实体可以通过满足每种类型的属性要求来符合任意数量的“类型”。
例如,您的模型可以要求:
:name
, :ssn
, :dob
:name
, :title
, :salary
:name
, :address
:id
, :plan
, :expiration
{:name "Brian" :ssn 123-45-6789 :dob 1976-09-15
:address "400 South State St, Chicago, IL 60605"
:id 42 :plan "Basic" :expiration 2012-05-01}
Person
,
Resident
和
Member
但不是
Employee
.
:id
也是 Employee
的一个属性?解决方案是将您的属性组织到命名空间中。所以你会同时拥有 :member/id
和 :employee/id
.提前这样做有助于避免以后发生冲突。 ALTER TABLE ALTER COLUMN
在这里用 SQL 的说法。现在,您可以使用正确的定义创建替换属性并移动现有数据。ALTER TABLE
时,这本质上是 RDBMS 在幕后所做的事情。 ,但你命名规则。 关于data-modeling - Datomic 中的数据建模,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10357778/
我正在寻找可以从 Eclipse 的 UML 图生成代码的工具。该工具应该从 UML 图生成代码,进行逆向工程以查看代码更改,并提供合并选项以防止因任何更改而删除文件。 是否有工具可以做到这一点,或者
我正在寻找有关建模的见解。我有一个关于设计模式和基本类图、序列图和用例的介绍类(class)。 我发现类图作为我编程中的组织工具非常宝贵。到目前为止,用例还算有用。 本学期我正在上课,更深入地学习 U
如何使用 flutter 数据建模技术访问“HH”和“mm”。我一直在尝试按以下方式使用它,但是下面给出了错误。 我的数据模型当前为它的简化版本。 class Week { final Strin
我正在使用 Neo4j 和 PHP。在我的项目中,我有餐厅节点。每个节点都有纬度、经度和分类属性。 我需要返回与用户给定分类相匹配的餐厅节点,其结果按距用户位置的距离排序(即第一个最近的餐厅)。 最简
我希望 POJO 包含一个 Status 字段(只有两个可能的值 SUCCESS、FAILED),并且根据此状态,第二个字段需要为 POJO 对象(如果 Status 为 SUCCESS) 或只是字符
我正在尝试将我的办公室迁移到数据库应用程序中。这是我得到的: (来源:phunkei.de) 公司和个人从客户继承(1:1关系)。这是因为他们都可以是“客户”并收到账单,我想引用订单中的单个表。公司和
我目前有这个数据库结构: 一个条目可以有多个"file"、“文本”和“url”类型的项目。 这些项目中的每一项在文本、网址或文件表(存储数据的位置)中都有一个对应的项目。 我需要一个查询来有效地选择一
下面的代码不应该像“if(condition)”语句一样工作吗,当它在另一个循环中并且“body”有自己的 break 或 continue 语句时,会出现明显的错误行为: for( ; condit
我一直在像这样存储和递增下载计数器: INCRBY downloads: 1 但现在我想要下载:* 按值排序,以便显示热门下载列表。 我觉得我可以更好地存储它。我愚弄了: ZINCRBY downlo
我开始使用图形数据库,在我的团队中,我们已经开始为我们的软件建模图形。当我们尝试“记录”模型以查看数据库的结构时,问题就出现了。对于 SQL 数据库,您只需查看 SQL 模式。 我们花了一些时间阅读
我正在做一个固定效应回归并且遇到了自相关问题,为了解决这个问题,我正在使用预测、lmtest 和 plm 包进行 ARIMA 建模。我的数据是一般面板数据,looks like this ,我正在尝试
我想知道是否有任何工具可以帮助我对 C 应用程序(即函数式编程)进行建模。例如。我目前正在构建一个共享库。但是为了直观地传达我的设计,我需要类似 UML 的东西。我想这样做,以便审查我的设计的人不需要
我正在尝试将 JSON 转换为 GSON ,但我无法建模。谁能给我举个例子。 [ { "id": "1", "name": "lalala",
正如标题所说,在 中建模 optional 参数的最佳方法是什么?斯卡拉 ? 对于 optional 参数,我的意思是执行函数体不需要的值。 要么因为该参数存在默认值,要么根本不需要该参数本身(例如配
我发现 UML 可用于记录 OO 系统的各个方面,尤其是用于整体架构的类图和用于说明特定例程的序列图。我想为我的 clojure 应用程序做同样的事情。我目前对模型驱动开发不感兴趣,只是在交流应用程序
我想知道是否有人知道如何使用 UML 在属性中建模 DateTime 基元类型? 最佳答案 我想这取决于日期的格式......请参阅下面的示例,其中我使用两个整数(分别为日和年)和一个名为“Month
我有一些与我的问题建模相关的问题。我正在研究基于模型的测试的论文项目。还想从专家的角度了解我是否采用正确的方法来建模我的场景。我正在对 Android 应用程序的 UI 进行建模,遍历它们,生成测试用
我正在尝试建立对 CouchDB 以及如何为某些现实世界场景建模数据的理解。我现在已经尽可能多地“按日期获取我的博客文章”;) 给定这样的文件: { "_id": "couch1",
一个模型资源是如何分层的?例如假设一个人有一个“留言板”并且“消息”是一种资源。假设“消息”可以有回复,从而形成一个讨论线程。如何模拟线程的概念? “消息”是否包含它的子项? “线程”是它自己的资源吗
我正在尝试创建一个像通用 POJO 一样工作的对象,因为我必须通过不同的对象传递它,并且我需要一个接口(interface)来访问其属性。 目前,我使用具有 getField 方法的基础对象来完成此操
我是一名优秀的程序员,十分优秀!