使用密码查询时,螺栓连接选择性地变慢,而基于Web的GUI总是很快

时间:2018-05-29 20:12:48

标签: neo4j cypher bolt neo4j-python-driver

我有两个问题:q1和q2。我使用下面的代码来查询我的neo4j数据库。

driver = GraphDatabase.driver("bolt://localhost:7687",auth= neo4j_user,neo4j_password))
neo4j_session = driver.session()

t = time.time()
neo4j_session.run(q1,q1_parameters) 
print(time.time()-t)

t = time.time()
neo4j_session.run(q2,q2_parameters) 
print(time.time()-t)

q1和q2都是由neo4j在网络界面(http://localhost:7474/browser/)中大约10毫秒执行的。上面的代码也在大约10 ms内执行q1,但q2在1s内执行。

为什么neo4j bolt连接不像特定的查询(q2),即使Web界面执行速度快100倍?我相信这不是连接开销,因为q1的执行方式几乎同样快

1 个答案:

答案 0 :(得分:1)

您不应该为每个查询创建新的驱动程序和会话。

Python Bolt驱动程序的README具有以下"快速示例"如何使用相同的driversession运行4个查询(3个写入和1个读取事务):

from neo4j.v1 import GraphDatabase

driver = GraphDatabase.driver("bolt://localhost:7687", auth=("neo4j", "password"))

def add_friends(tx, name, friend_name):
    tx.run("MERGE (a:Person {name: $name}) "
           "MERGE (a)-[:KNOWS]->(friend:Person {name: $friend_name})",
           name=name, friend_name=friend_name)

def print_friends(tx, name):
    for record in tx.run("MATCH (a:Person)-[:KNOWS]->(friend) WHERE a.name = $name "
                         "RETURN friend.name ORDER BY friend.name", name=name):
        print(record["friend.name"])

with driver.session() as session:
    session.write_transaction(add_friends, "Arthur", "Guinevere")
    session.write_transaction(add_friends, "Arthur", "Lancelot")
    session.write_transaction(add_friends, "Arthur", "Merlin")
    session.read_transaction(print_friends, "Arthur")