TinkerPop:按具有特定属性的边缘计数过滤

时间:2019-03-27 16:49:34

标签: python-2.7 gremlin

具有下图:

DIAGRAM

我想吸引位置2上至少有两个帖子的用户。

我试图通过他的属性来计算过滤的边缘,但是什么也没发生:

g.V().hasLabel("user").outE('POST').outV().filter(outE('LOCATED_AT').limit(2).has('country_code', 'CZ').count().is_(2)).count().toList()

查询实际上返回超时。我花了很多时间寻找一种方法来做到这一点,但是没人能复制这个查询。

1 个答案:

答案 0 :(得分:0)

获取在位置2上至少有两个帖子的用户:

from gremlin_python.structure.graph import Graph
from gremlin_python.process.traversal import T, Column, P
from gremlin_python.process.graph_traversal import __

g.V().hasLabel("user").filter(__.outE('POST').inV().out('LOCATED_AT').has('country_code', 'CZ').groupCount().unfold().select(Column.values).is_(P.gte(2))).toList()

在您的图中,找不到属性country_code的放置位置,因此生成图的代码如下:

g.addV('user').property('Id', 1).property(T.id, '11').iterate()
g.addV('user').property('Id', 2).property(T.id, '12').iterate()

g.addV('media').property('Id', 1).property(T.id, '21').iterate()
g.addV('media').property('Id', 2).property(T.id, '22').iterate()
g.addV('media').property('Id', 3).property(T.id, '23').iterate()
g.addV('media').property('Id', 4).property(T.id, '24').iterate()

g.addV('location').property('Id', 1).property(T.id, '31').property('country_code', 'CZ').iterate()
g.addV('location').property('Id', 2).property(T.id, '32').property('country_code', 'CZ').iterate()
g.addV('location').property('Id', 3).property(T.id, '33').property('country_code', 'CZ').iterate()

g.addE('POST').from_(g.V('11')).to(g.V('21')).iterate()
g.addE('POST').from_(g.V('11')).to(g.V('22')).iterate()
g.addE('POST').from_(g.V('11')).to(g.V('23')).iterate()
g.addE('POST').from_(g.V('12')).to(g.V('24')).iterate()

g.addE('LOCATED_AT').from_(g.V('21')).to(g.V('31')).iterate()
g.addE('LOCATED_AT').from_(g.V('22')).to(g.V('32')).iterate()
g.addE('LOCATED_AT').from_(g.V('23')).to(g.V('32')).iterate()
g.addE('LOCATED_AT').from_(g.V('24')).to(g.V('32')).iterate()
g.addE('LOCATED_AT').from_(g.V('24')).to(g.V('33')).iterate()