2017-08-03 21:53:41 +08:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
2020-10-16 18:49:33 +08:00
|
|
|
from neo4j import GraphDatabase, basic_auth
|
2017-11-07 17:22:16 +08:00
|
|
|
from neo4j.exceptions import ClientError, TransientError
|
2017-08-03 21:53:41 +08:00
|
|
|
|
|
|
|
def tx_error(tx, name, name2):
|
2020-10-16 18:49:33 +08:00
|
|
|
a = tx.run("CREATE (a:Person {name: $name}) RETURN a", name=name).value()
|
|
|
|
print(a[0])
|
2017-08-03 21:53:41 +08:00
|
|
|
tx.run("CREATE (").consume()
|
2020-10-16 18:49:33 +08:00
|
|
|
a = tx.run("CREATE (a:Person {name: $name}) RETURN a", name=name2).value()
|
|
|
|
print(a[0])
|
2017-08-03 21:53:41 +08:00
|
|
|
|
|
|
|
def tx_good(tx, name, name2):
|
2020-10-16 18:49:33 +08:00
|
|
|
a = tx.run("CREATE (a:Person {name: $name}) RETURN a", name=name).value()
|
|
|
|
print(a[0])
|
|
|
|
a = tx.run("CREATE (a:Person {name: $name}) RETURN a", name=name2).value()
|
|
|
|
print(a[0])
|
2017-08-03 21:53:41 +08:00
|
|
|
|
2017-10-09 22:09:17 +08:00
|
|
|
def tx_too_long(tx):
|
2017-11-07 17:22:16 +08:00
|
|
|
tx.run("MATCH (a), (b), (c), (d), (e), (f) RETURN COUNT(*) AS cnt")
|
|
|
|
|
|
|
|
with GraphDatabase.driver("bolt://localhost:7687", auth=basic_auth("", ""),
|
|
|
|
encrypted=False) as driver:
|
|
|
|
|
|
|
|
def add_person(f, name, name2):
|
|
|
|
with driver.session() as session:
|
|
|
|
session.write_transaction(f, name, name2)
|
|
|
|
|
|
|
|
# Wrong query.
|
|
|
|
try:
|
|
|
|
add_person(tx_error, "mirko", "slavko")
|
|
|
|
except ClientError:
|
|
|
|
pass
|
|
|
|
# Correct query.
|
|
|
|
add_person(tx_good, "mirka", "slavka")
|
|
|
|
|
|
|
|
# Setup for next query.
|
|
|
|
with driver.session() as session:
|
2020-10-16 18:49:33 +08:00
|
|
|
session.run("UNWIND range(1, 100000) AS x CREATE ()").consume()
|
2017-11-07 17:22:16 +08:00
|
|
|
|
|
|
|
# Query that will run for a very long time, transient error expected.
|
2018-08-22 22:05:38 +08:00
|
|
|
timed_out = False
|
|
|
|
try:
|
|
|
|
with driver.session() as session:
|
2020-10-16 18:49:33 +08:00
|
|
|
session.run("MATCH (a), (b), (c), (d), (e), (f) RETURN COUNT(*) AS cnt").consume()
|
2018-08-22 22:05:38 +08:00
|
|
|
except TransientError:
|
|
|
|
timed_out = True
|
|
|
|
|
|
|
|
if timed_out:
|
|
|
|
print("The query timed out as was expected.")
|
|
|
|
else:
|
|
|
|
raise Exception("The query should have timed out, but it didn't!")
|
2017-11-07 17:22:16 +08:00
|
|
|
|
|
|
|
print("All ok!")
|