neo4j vs python

1.将库中已经存在的两个节点,创建关系。

查询库中只有2个独立的节点。

方式一,python,使用py2neo库

python 复制代码
#coding:utf-8
from py2neo import Graph,Node,Relationship,NodeMatcher
 
##连接neo4j数据库,输入地址、用户名、密码
graph = Graph('bolt://xx.xx.xx.xx:7687',auth=("neo4j","neo4j1234"))

hd = graph.nodes.match("person",name="宋太祖").first()
hh = graph.nodes.match("person",name="皇后").first()

graph.create(Relationship(hd,"夫妻",hh))

执行成功

查看库

方式二:使用neo4j, 原生cypher语句

python 复制代码
#coding:utf-8
from neo4j import GraphDatabase

##获取已经存在的节点,创建关系
driver = GraphDatabase.driver('bolt://xx.xx.xx.xx:7687',auth=("neo4j","neo4j1234"))

with driver.session() as session:
    hd = session.run("MATCH (a:person {name:'宋太祖'}) return a").single().get("a")
    hh = session.run("MATCH (b:person {name:'皇后'}) RETURN b").single().get("b")

    session.run("Match (a:person), (b:person) where a.name='皇后' and b.name='宋太祖' create (a) - [:老婆] -> (b)")
driver.close()

查看库

看着上面的脚本就奇怪,那获取节点干嘛呢,信息存入了变量里,后面又没用到这个变量。

直接用最后面的cypher语句,不就能执行了嘛。执行一次,没报错,查看库

果然不需要那两句,直接match查询就可以。

总结

通过这两个方式也看出来了,还是用封装好的方法操作便捷,出错的概率也小。

相关推荐
MediaTea6 分钟前
Python:实例 __dict__ 详解
java·linux·前端·数据库·python
SunnyDays10117 分钟前
Python Excel 打印设置全攻略(打印区域、缩放、页边距、页眉页脚等)
python·excel打印设置·excel页面设置·excel打印选项
小鸡吃米…9 分钟前
Python的人工智能-机器学习
人工智能·python·机器学习
stevenzqzq10 分钟前
Compose基础入门
开发语言·compose
米优11 分钟前
C/C++中实现自定义自动释放堆内存空间类
c语言·开发语言·c++
傻啦嘿哟20 分钟前
Python上下文管理器:优雅处理资源释放的魔法工具
开发语言·python
阿方索21 分钟前
Python 基础简介
开发语言·python
Data_agent24 分钟前
CNFANS模式淘宝1688代购系统搭建指南
大数据·开发语言·前端·javascript
Sammyyyyy30 分钟前
MongoDB 的文档模型与 CRUD 实战
开发语言·数据库·mongodb·servbay