在 Graph 数据库中使用时间戳(开始日期和结束日期)实现软删除的最佳方法是什么?
问问题
103 次
1 回答
3
好吧,根据时间戳来隐藏遍历是相当简单的。以这个示例图为例,“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
于 2021-05-07T11:26:05.613 回答