使用Python匹配ArangoDb中顶点上的数组中的属性

时间:2015-10-23 13:51:47

标签: python arangodb

我有顶点[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)

但是没有任何回报! 如果我尝试除数组以外的其他属性,它可以正常工作。

2 个答案:

答案 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"