neo4j使用教程(2)初步使用py2neo

  • 之前的教程中我们讲述了如何在linux系统下构建起neo4j 服务器,但是没有试过用我们最常见的语言接口对服务器进行创建节点,关系等常规操作,今天我们将重点讲述如何使用py2neo进行数据库连接,节点 关系创建等操作;

  • 首先讲述的是如何安装py2neo,这个是老生常谈

pip install py2neo --user
  • 一般默认安装的是最新版本的,我测试的时候使用的是3.1.2版本的;

  • 其次,我们来尝试下数据库连接方式,感谢万能的python社区,py2neo中的接口可以用简单、可靠来形容;

#################################################
# g是这个python中获取到的数据库句柄,后续可以通过这个g来
# 进行创建,查询,删除等各种操作;
#################################################
from py2neo import Graph,Node,Relationship
g = Graph(
    host = "1.1.1.1", # neo4j 搭载服务器的ip地址,ifconfig可获取到
    http_port = 7978, # neo4j 服务器监听的端口号  
    user = "neo4j", # 数据库user name,如果没有更改过,应该是neo4j
    password = "******" # 自己设定的密码
)
  • 为了更好的尝试py2neo的创建功能,我们需要在下面中编写几个样本例子,其中包括node,以及node之间的relationship。
def test_create_node():
    global g
    """
    g.delete_all()
    tx = g.begin()
    worker_1 = {"name":"allen","age":13,"company":"google inc"}
    worker_2 = {"name":"john","age":24,"company":"microsoft inc"}
    node_1 = Node("WORKER",**worker_1)
    node_2 = Node("WORKER",**worker_2)
    rel_1_2 = Relationship(node_1,"CO_WORKER",node_2)
    tx.merge(node_1)
    tx.merge(node_2)
    tx.merge(rel_1_2)
    tx.commit()
    """
    g.delete_all()
    tx = g.begin()
    # in loop mode
    worker_list = [
        {"name":"allen","age":13,"company":"google inc"},
        {"name":"john","age":24,"company":"microsoft inc"}
    ]
    for worker in worker_list:
        node = Node("WORKER",**worker)
        tx.merge(node)
    node1 = Node(name="allen")
    node2 = Node(name="john")
    rel = Relationship(node1,"CO_WORKER",node2)
    tx.merge(rel)
    tx.commit()
  • g.delete_all()将会删除数据库中所有的节点和关系,g.begin()是一定要放在执行代码的前面的,作者在上述的脚本中使用了两种模式,一种是顺序添加,就是被注释掉的那块,这样做是为了体会流程,一种是用循环方式添加,工程中可以将节点放到文件中,使用循环方式添加,高效,快捷;在创建节点的时候建议使用 tx.merge,这个相当于create if not exist,很多事情不用自己操心,最后提交tx.commit(),将所有的东西都会push到远端的neo4j服务器上,最后我们可以在neo4j的html界面上,输入 以下命令,前端中就会显示刚才创建的节点和关系:
MATCH p=()-[r:CO_WORKER]->() RETURN p LIMIT 25
neo4j api neo4j学习资料 neo4j教程 │ neo4j官方API(官方各种API的文档整理).7z │ neo4j数据迁移--初探(一).htm │ neo4j笔记.docx │ neo4j错误码状态码.html │ └─01.neo4j学习博客汇总 │ index.html └─neo4j_cypher │ Cypher(神奇的WITH).html │ cypher_index.html │ Cypher查询语言--Neo4j 综合(四) - divenswu - 博客园.html │ Cypher查询语言--Neo4j中的SQL - 爱上包子 - 博客园.html │ DETACH DELETE n 删除node n ,并删除所有与n相关的关系.html │ Neo4j - NOT IN query.html │ Neo4j CQL - (11)- REMOVE删除 DELETE.html │ Neo4j Cypher 复杂查询详解在之With - 何源浩的博客 - CSDN博客.html │ neo4j使用sparql查询.html │ Neo4j 中文社区,致力于 Neo4j 的技术研究。.html │ Neo4j 使用cypher语言进行查询 - MHL - 博客园.html │ Neo4j 第一篇:在Windows环境中安装Neo4j - 悦光阴 - 博客园.html │ Neo4j 第三篇:Cypher查询入门 - 悦光阴 - 博客园.html │ Neo4j 第二篇:图形数据库 - 悦光阴 - 博客园.html │ Neo4j 第五篇:批量更新数据 - 悦光阴 - 博客园.html │ Neo4j 第四篇:使用C更新和查询Neo4j - 悦光阴 - 博客园.html │ Neo4J(Cypher语句)初识.html │ Neo4J(Cypher语句)学习 - 赵晓雷的专栏 - CSDN博客.html │ Neo4j_事务&深度遍历.html │ neo4j中的分组查询.html │ Neo4j之Cypher学习总结.html │ NEO4J亿级数据导入导出以及数据更新 - 耶和华靠近伤心的人,拯救灵性痛悔的人 - CS.html │ Neo4j入门点滴(一):Cypher.html │ Neo4j入门点滴(三):用Cypher完善图.html │ Neo4j入门点滴(二):模式与模式匹配.html │ Neo4j入门点滴(五):Windows Shell for Cypher.html │ Neo4j入门点滴(四):Cypher查询优化.html │ Neo4J几种数据导入方式的效率对比 - 何源浩的博客 - CSDN博客.html │ Neo4j模糊查询及分页查询 - c1052981766的专栏 - CSDN博客.html │ neo4j笔记 - Neo4j 中文社区.html │ Neo4j语句 - zhuweiba_321的博客 - CSDN博客.html │ Neo4j语句 - 阿里云.html │ 【程裕强的专栏】大数据学习笔记(1.01^365=37.78,0.99^365=0.025.html │ 五岳之巅-Neo4j入门点滴-博文目录.html │ 关于Neo4j和Cypher批量更新和批量插入优化的5个建议 - 逆水行舟 - CSDN博.html │ 图数据库-Neo4j介绍与Cypher入门.html │ 图数据库之Cypher语言 - 活的洒脱怪我咯的专栏 - CSDN博客.html │ 图数据库neo4j-jdbc的使用 - 活的洒脱怪我咯的专栏 - CSDN博客.html │ 数据分页处理系列之三:Neo4j图数据分页处理.html │ 暖暖动听.html │ 飘涯 - 简书.html
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值