使用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() 来实现,如上述示例所示。

相关推荐
青衫客361 小时前
基于 Python 构建的安全 gRPC 服务——TLS、mTLS 与 Casbin 授权实战
python·安全·微服务
-dzk-2 小时前
【3DGS复现】Autodl服务器复现3DGS《简单快速》《一次成功》《新手练习复现必备》
运维·服务器·python·计算机视觉·3d·三维重建·三维
摩羯座-185690305943 小时前
爬坑 10 年!京东店铺全量商品接口实战开发:从分页优化、SKU 关联到数据完整性闭环
linux·网络·数据库·windows·爬虫·python
ACERT3333 小时前
5.吴恩达机器学习—神经网络的基本使用
人工智能·python·神经网络·机器学习
韩立学长3 小时前
【开题答辩实录分享】以《基于python的奶茶店分布数据分析与可视化》为例进行答辩实录分享
开发语言·python·数据分析
2401_831501734 小时前
Python学习之day03学习(文件和异常)
开发语言·python·学习
编程充电站pro4 小时前
SQL 面试高频:INNER JOIN vs LEFT JOIN 怎么考?
数据库·sql
这周也會开心4 小时前
SQL-窗口函数做题总结
数据库·sql
间彧4 小时前
TiDB详解与Spring Boot实战指南
数据库
极限实验室4 小时前
Easysearch 字段'隐身'之谜:source_reuse 与 ignore_above 的陷阱解析
数据库·redis