首页 > 解决方案 > 在 Graph 数据库中执行软删除的最佳方法是什么?

问题描述

在 Graph 数据库中使用时间戳(开始日期和结束日期)实现软删除的最佳方法是什么?

标签: databasegraphgremlinamazon-neptuneproperty-graph

解决方案


好吧,根据时间戳来隐藏遍历是相当简单的。以这个示例图为例,“ts”是一个以长表示的模拟时间戳:

gremlin> g.addV('person').property('name','alice').as('a').
......1>   addV('person').property('name','bob').as('b').
......2>   addV('person').property('name','claire').as('c').
......3>   addE('interacted').property('ts', 125).from('a').to('b').
......4>   addE('interacted').property('ts', 126).from('a').to('b').
......5>   addE('interacted').property('ts', 127).from('a').to('b').
......6>   addE('interacted').property('ts', 126).from('b').to('c').
......7>   addE('interacted').property('ts', 150).from('b').to('c').
......8>   addE('interacted').property('ts', 151).from('a').to('b').iterate()

您可以简单地编写 Gremlin 来解释“ts”:

gremlin> yesterday = 130
==>130
gremlin> g.V().has('person','name','alice').
......1>   outE('interacted').has('ts',gt(yesterday)).inV().
......2>   values('name')
==>bob

根据您要求的复杂性,在“ts”上添加此过滤器可能会变得繁琐并使您的代码混乱。如果是这种情况,可能SubgraphStrategy会有所帮助:

gremlin> sg = g.withStrategies(SubgraphStrategy.build().edges(has('ts',gt(yesterday))).create())
==>graphtraversalsource[tinkergraph[vertices:3 edges:6], standard]
gremlin> sg.V().has('person','name','alice').out('interacted').values('name')
==>bob
gremlin> g.V().has('person','name','alice').out('interacted').values('name')
==>bob
==>bob
==>bob
==>bob

推荐阅读