我有一个对象,我需要保留对它所做的所有更改的历史记录。我将如何使用neo4j实现这一点?
2 回答
与 RDBMS 一样,它取决于您的域和数据查询要求。
您的应用程序是否需要定期访问对象的所有版本,或者通常只访问最新版本,而旧版本可通过当前版本获得?这方面的一个例子可能是维基百科上的页面。例如,假设我们有一个版本为 3 的页面。然后我们可以对其建模如下:
(pages)-[:PAGE]->(V3)-[:PREV]->(V2)-[:PREV]->(V1)
^ ^
| |
category current
node version of page
在这里,只能看到当前版本构成主要结构的一部分,但您可能希望允许所有版本构成该结构的一部分。在这种情况下,您可以使用关系属性来指示版本并从类别节点链接所有页面版本:
(V1)
^
|
[:PAGE(v=1)]
|
(pages)-[:PAGE(v=2)]->(V2)
|
[:PAGE(v=3)]
|
v
(V3)
在这里,您只需指定您感兴趣的版本即可立即遍历到页面的特定版本。
第三种选择可能是您希望所有旧版本与主结构完全分离。为此,您可以使用多个类别节点,一个 for (current_pages)
,另一个 for (old_pages)
。由于每个页面都被新版本取代,因此它与前一个类别取消链接,而是链接到后者。这将形成更多的“存档”类型的系统,其中旧版本甚至可以移动到单独的数据库实例中。
所以你有这三个选项,还有更多我没有想到的!Neo4j 为您提供了这种设计的极大灵活性,并且绝对没有“正确”的答案。但是,如果这些都不能激发您的灵感,请发布有关您的域的更多信息,以便可以根据您的需求量身定制答案。
干杯,尼日
你也可以从另一边接近它:
(pages)-[:VERSION]->(V1)-[:VERSION]->(V2)-[:VERSION]->(V3)
^ ^
| |
category current
node version of page
优点:创建新版本时,只需将其添加到链的末尾,无需在(页面)和当前版本之间“插入”它。
缺点:你不能只扔掉旧版本,除非你重建链条。但这可能不是一个频繁的操作。