我使用以下代码成功合并节点:
session = cypher.Session('http://192.168.56.20:7474/db/data/')
txa = session.create_transaction()
txa.append("""
MERGE (frame:FRAME {timestamp:{props}.ts})
ON CREATE SET frame:FIRST_FRAME
RETURN frame
""", props)
txa.commit()
result, = txa.commit()
frame, = result[0]
日志文件如下所示:
INFO:py2neo.packages.httpstream.http:>>> POST http://192.168.56.20:7474/db/data/transaction/commit [910]
DEBUG:py2neo.packages.httpstream.http:>>> Host: 192.168.56.20:7474
DEBUG:py2neo.packages.httpstream.http:>>> Content-Type: application/json
DEBUG:py2neo.packages.httpstream.http:>>> X-Stream: true;format=pretty
DEBUG:py2neo.packages.httpstream.http:>>> User-Agent: py2neo/1.6.1 HTTPStream/1.1.0 Python/2.7.5-final-0 (darwin)
INFO:py2neo.packages.httpstream.http:<<< 200 OK [chunked]
DEBUG:py2neo.packages.httpstream.http:<<< transfer-encoding: chunked
DEBUG:py2neo.packages.httpstream.http:<<< access-control-allow-origin: *
DEBUG:py2neo.packages.httpstream.http:<<< server: Jetty(9.0.5.v20130815)
DEBUG:py2neo.packages.httpstream.http:<<< content-type: application/json
DEBUG:py2neo.packages.httpstream.http:<<< content-encoding: UTF-8
返回的结果变量是:
[Record(columns=(u'frame',), values=(Node('http://0.0.0.0:7474/db/data/node/24'),))]
注意错误的 uri (0.0.0.0)
当我尝试使用返回的节点实例时,会引发连接异常。IE:
frame.remove_labels('FIRST_FRAME')
py2neo.packages.httpstream.http.SocketError: Connection refused
通过记录的跟踪,我可以看到它试图从错误的服务器获取数据:
INFO:py2neo.packages.httpstream.http:>>> GET http://0.0.0.0:7474/db/data/node/24/properties
我究竟做错了什么?