我有顶点[a]的文档,它与文档[b]的顶点有一个边界,我想知道如何遍历顶点数组[a]:
[a]: {"name": "Tom", "age": 30, "colors": ["green", "blue", "red"]}
[b}: {"city", "NY"}
我尝试如下:
mydb.execute_query cursor = (
"""
FOR i IN GRAPH_NEIGHBORS (
'my_graph', 'citys/ny',
{neighborExamples: {colors: 'green'}}
) RETURN i
"""
)
for doc in cursor:
print (doc)
但是没有任何回报! 如果我尝试除数组以外的其他属性,它可以正常工作。
答案 0 :(得分:2)
现在GRAPH_NEIGHBORS()仅支持示例的相等比较。 您要查询的是"绿色"在颜色。 现在只能通过后过滤表示。 像这样:
mydb.execute_query cursor = ( """
FOR i IN GRAPH_NEIGHBORS ('my_graph', 'citys/ny', {})
FILTER 'green' IN i.colors RETURN i
""" ) doc is in cursor:
print (doc)
应该给你想要的结果。
答案 1 :(得分:1)
感谢mchacki和dothebarth,你让我意识到除了向我展示我如何进行搜索之外,还间接地向我展示了我使用了错误的功能。我做了下面的代码,运行得很好。谢谢!
cursor = mydb.execute_query(
"""
FOR i IN GRAPH_VERTICES(
'my_graph',
{city:'NY'},
{}
)
FILTER 'green' IN i.colors
RETURN i.name
"""
)
for doc in cursor:
print(doc)
>>"Tom"