python连接neo4j的方式汇总

python连接neo4j的方式汇总

1.官方驱动(neo4j)

特点

  • 官方维护,支持Neo4j 5.x所有新特性(如分片集群、时序图)
  • 提供同步/异步API,兼容asyncio和Reactive Streams
  • 与APOC插件深度集成,支持存储过程调用

代码示例

from neo4j import GraphDatabase 

driver = GraphDatabase.driver("bolt://localhost:7687",  auth=("neo4j", "password"))
with driver.session()  as session:
    result = session.run("MATCH  (n:User) RETURN n.name  LIMIT 10")
    print([record["n.name"]  for record in result])

# 关闭驱动
driver.close()

2. 全功能ORM(py2neo)

特点

  • 支持节点/关系对象化操作,内置子图事务管理
  • 集成GIS空间数据处理(WKT格式与Neo4j Spatial插件兼容)
  • 提供GraphQL转换工具,一键生成API端点

代码示例

from py2neo import Graph, Node 

graph = Graph("bolt://localhost:7687", auth=("neo4j", "password"))
user = Node("User", name="Alice", age=30)
graph.create(user)   # 自动提交事务 

3. 领域驱动设计框架(neomodel-odm)

特点

  • 类Django的声明式模型定义,支持DDD模式(聚合根、值对象)
  • 自动生成数据库迁移脚本,兼容CI/CD流水线
  • 内置事件溯源(Event Sourcing)和CQRS模式支持

代码示例

from neomodel_odm import StructuredNode, StringProperty 

class Product(StructuredNode):
    sku = StringProperty(unique_index=True)
    name = StringProperty(required=True)

# 自动创建唯一约束并持久化 
Product(sku="P-2025", name="Quantum Laptop").save()

4. 异步高性能驱动(asyncneo4j)

特点

  • 专为微服务设计,支持万级并发连接
  • 内置连接池自动扩缩容与故障转移机制
  • 优化Bolt协议二进制编码,降低网络开销30%

代码示例

from asyncneo4j import Neo4jClient 

client = Neo4jClient("bolt://cluster-node:7687", pool_size=20)
async with client.transaction()  as tx:
    await tx.execute("CREATE  (:Log {level: $level})", level="INFO")
相关推荐
JioJio~z7 分钟前
MYSQL之创建数据库和表
数据库·mysql
WenGyyyL9 分钟前
使用OpenCV和MediaPipe库——驼背检测(姿态监控)
人工智能·python·opencv·算法·计算机视觉·numpy
蹦蹦跳跳真可爱58922 分钟前
Python----数据分析(Matplotlib四:Figure的用法,创建Figure对象,常用的Figure对象的方法)
python·数据分析·matplotlib
小杨4041 小时前
python入门系列六(文件操作)
人工智能·python·pycharm
RainbowSea1 小时前
6. MySQL 索引的数据结构(详细说明)
数据库·sql·mysql
jk_1011 小时前
MATLAB中strip函数用法
java·服务器·数据库
XiYang-DING1 小时前
【数据库系统概论】第七章 数据库设计
数据库
xiaozaq2 小时前
在Eclipse中安装Lombok插件
java·python·eclipse
云空2 小时前
《FastRTC:开启实时音视频应用开发新时代》
python·实时音视频
尘鹄2 小时前
一文讲懂Go语言如何使用配置文件连接数据库
开发语言·数据库·后端·golang