使用py2neo时在节点之间创建批处理关系的例外情况

时间:2013-12-18 09:04:40

标签: python neo4j py2neo

我使用py2neo创建了一个图形数据库,其目的是:

  • 为每个城市创建一个节点。该节点存储城市名称和与之关联的唯一ID。
  • 为每个机场创建一个节点。机场节点存储机场名称,并再次存储唯一ID。
  • 如果机场在该城市,则在城市节点和机场节点之间创建关系。

我使用此模块首先(成功)创建了城市节点:

batch = neo4j.WriteBatch(graph_db)    
for city_id,city_name in <some_list>:
     city_node_id = batch.create(node(city_id=city_id, name=city_name))
     batch.add_indexed_node('city_index','city_id',city_id, city_node_id)
batch.submit()

然后在另一个单独的模块中,我尝试创建机场节点以及机场节点和相应城市节点之间的关系,如下所示:

read_batch = neo4j.ReadBatch(graph_db)
write_batch = neo4j.WriteBatch(graph_db)
for airport_id, city_id, airport_name in <some_list>:
    airport_node_id = write_batch.create(node(airport_id=airport_id, city_id=city_id, name=airport_name)) 
    write_batch.add_indexed_node('airport_index','airport_id',airport_id, airport_node_id)
    city_node_id = read_batch.get_indexed_nodes('city_index','city_id',city_id)
    rel_id = write_batch.create(rel(airport_node_id, "is in city", city_node_id))
    write_batch.add_indexed_relationship('airport_rel_index','airport_id',airport_id, rel_id)
write_batch.submit()

我在创建关系的第三个声明是抛出异常:

rel_id = write_batch.create(rel(airport_node_id, "is in city", city_node_id))
File "/usr/local/lib/python2.7/dist-packages/py2neo/neo4j.py", line 2695, in create
"to": self._uri_for(entity.end_node)
File "/usr/local/lib/python2.7/dist-packages/py2neo/neo4j.py", line 2537, in _uri_for
uri = "{{{0}}}".format(self.find(resource))
File "/usr/local/lib/python2.7/dist-packages/py2neo/neo4j.py", line 2528, in find
raise ValueError("Request not found")
  ValueError: Request not found

我试图打印这两种节点的uri。他们是有区别的:

print station_node_id._uri, city_node_id._uri

输出:

node index/node/city_index/city_id/2536650

因此两个节点的uris都不同,这就是为什么我猜这种关系没有被创建。

我可以使用什么函数返回城市的无索引节点,即uri应该只是“节点”而不是“index / node / city_index / city_id /”。

有没有其他方法可以创建这种关系?

如果需要,我很乐意提供任何其他信息。 提前谢谢!

Neo4j:1.9.5

py2neo:1.6.1

1 个答案:

答案 0 :(得分:1)

您所看到的是一个令人遗憾的服务器限制,其中某些REST调用返回的位置URI包含节点索引条目URI而不是标准节点URI。不幸的是,这仅在少数用例中有用,并且在像您这样的情况下是一个主要限制。

这里讨论了一个类似的问题 - https://github.com/nigelsmall/py2neo/issues/221 - 很遗憾,我无法从客户端做到这一点。

您唯一真正的选择是将您的工作分成多个批次,或者 - 如果您能够这样做 - 考虑升级到Neo4j 2.0,您可以使用新的标签和架构索引功能。