使用Python 访问Neo4J 数据库

前期准备工作

安装Neo4j Python库

要与Neo4j数据库交互,你需要安装Neo4j的Python客户端库。可以通过以下命令安装:

bash 复制代码
pip install neo4j

基本步骤

以下是使用Neo4j的基本步骤,每一步都包含了详细的说明:
引入库 定义连接参数 创建驱动实例 创建会话 执行Cypher查询 处理查询结果 关闭会话和驱动 其它业务操作

代码示例

2.1 执行单行查询语句

以下是一个执行单行Cypher查询语句的示例,用于查询数据库中的前五个节点。

python 复制代码
from neo4j import GraphDatabase

# 连接Neo4j数据库
uri = "bolt://192.168.0.104:7687"  # Neo4j的地址,通常为 localhost 或者实际服务器的IP
username = "neo4j"              # 用户名,默认通常是 neo4j
password = "12345678"           # 密码

# 创建驱动实例
driver = GraphDatabase.driver(uri, auth=(username, password))

# 创建一个会话
with driver.session() as session:
    # 写一个Cypher查询语句
    query = "MATCH (n) RETURN n LIMIT 5"  # 查询前五个节点

    # 执行查询
    result = session.run(query)

    # 处理结果
    for record in result:
        print(record["n"])

2.2 执行多行查询语句

Neo4j要求每个查询只有一个语句。如果想在一个会话中执行多个Cypher语句,需要将它们分开执行。以下是分开执行的示例:

python 复制代码
from neo4j import GraphDatabase

# 连接Neo4j数据库
uri = "bolt://192.168.0.104:7687"
username = "neo4j"
password = "12345678"

# 尝试连接数据库
try:
    driver = GraphDatabase.driver(uri, auth=(username, password))
    with driver.session() as session:
        # 分别执行每个Cypher查询语句
        queries = [
            "CREATE (biological:Biological {name: 'Biological'})",
            "CREATE (plant:Plant {name: 'Plant1'})",
            "CREATE (herb:Herb {name: 'Herb1'})",
            "CREATE (animal:Animal {name: 'Animal'})",
            "CREATE (dog:Animal {name: 'Dog'})",
            "CREATE (cow:Animal {name: 'Cow'})",
            "MATCH (herb:Herb), (plant:Plant) WHERE herb.name = 'Herb1' AND plant.name = 'Plant1' CREATE (herb)-[:IS_A]->(plant)",
            "MATCH (plant:Plant), (biological:Biological) WHERE plant.name = 'Plant1' AND biological.name = 'Biological' CREATE (plant)-[:IS_A]->(biological)",
            "MATCH (animal:Animal), (biological:Biological) WHERE animal.name = 'Animal' AND biological.name = 'Biological' CREATE (animal)-[:IS_A]->(biological)",
            "MATCH (dog:Animal), (animal:Animal) WHERE dog.name = 'Dog' AND animal.name = 'Animal' CREATE (dog)-[:IS_A]->(animal)",
            "MATCH (cow:Animal), (animal:Animal) WHERE cow.name = 'Cow' AND animal.name = 'Animal' CREATE (cow)-[:IS_A]->(animal)",
            "MATCH (cow:Animal {name: 'Cow'}), (herb:Herb {name: 'Herb1'}) WHERE cow.name = 'Cow' AND herb.name = 'Herb1' CREATE (cow)-[:EATS]->(herb)"
        ]

        # 执行每个查询
        for query in queries:
            session.run(query)

except Exception as e:
    print(f"An error occurred: {e}")
finally:
    # 确保驱动程序被关闭
    driver.close()

2.3 错误处理和资源管理

在上述示例中,我们使用了 try...except...finally 结构来处理可能发生的异常,并确保数据库连接在操作完成后被正确关闭。这是一种良好的编程实践,可以防止资源泄露和未处理的异常。

2.4 事务管理

在Neo4j中,每个会话都是一个事务。你可以在一个会话中执行多个Cypher语句,但是每个语句都是独立的事务。如果你需要执行一系列操作作为一个单一的事务,你可以使用事务API来显式地管理事务。

2.5 关闭数据库连接

在完成所有数据库操作后,确保关闭数据库连接是一个重要的步骤。这可以通过 finally 块中的 driver.close() 来实现,如上述示例所示。

相关推荐
l1t39 分钟前
利用DeepSeek实现服务器客户端模式的DuckDB原型
服务器·c语言·数据库·人工智能·postgresql·协议·duckdb
酷飞飞4 小时前
Python网络与多任务编程:TCP/UDP实战指南
网络·python·tcp/ip
MarkHard1235 小时前
如何利用redis使用一个滑动窗口限流
数据库·redis·缓存
数字化顾问5 小时前
Python:OpenCV 教程——从传统视觉到深度学习:YOLOv8 与 OpenCV DNN 模块协同实现工业缺陷检测
python
学生信的大叔6 小时前
【Python自动化】Ubuntu24.04配置Selenium并测试
python·selenium·自动化
island13146 小时前
【Redis#10】渐进式遍历 | 数据库管理 | redis_cli | RES
数据库·redis·bootstrap
心想事成的幸运大王6 小时前
Redis的过期策略
数据库·redis·缓存
倔强的石头_6 小时前
CentOS 上安装KingbaseES(ISO包)详细教程
数据库
2401_897930067 小时前
使用Docker轻松部署Neo4j图数据库
数据库·docker·neo4j
诗句藏于尽头7 小时前
Django模型与数据库表映射的两种方式
数据库·python·django