我有两个问题: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的执行方式几乎同样快
答案 0 :(得分:1)
您不应该为每个查询创建新的驱动程序和会话。
Python Bolt驱动程序的README具有以下"快速示例"如何使用相同的driver
和session
运行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")