Neo4j学习笔记1:增删改查

news/发布时间2024/6/16 10:20:48

目录

  • 安装
  • 练习节点和关系结构
  • 连接数据库
  • 添加节点
    • 1. Cypher
    • 2. Py2neo
  • 添加关系
    • 1. Cypher
    • 2. Py2neo
  • 批量添加
    • 1. Cypher
    • 2. Py2neo
  • 查询
    • 1. Cypher
    • 2. Py2neo
  • 更新
    • 1. Cypher
    • 2. Py2neo
  • 删除
    • 1. Cypher
    • 2. Py2neo

安装

这边直接下载了Neo4j Desktop+安装py2neo,安装后就可直接使用

pip install py2neo

练习节点和关系结构

类型字段1字段2字段3字段4
nodeidnametypeindustry
linksourcerelationtarget-

连接数据库

Desktop直接打开,用Neo4j Browser打开就行,很方便
下面这个是使用Py2neo库链接数据库

from py2neo import Graph, Node, Relationship# 连接到Neo4j
graph = Graph("bolt://localhost:7687", auth=("neo4j", "password"))

添加节点

1. Cypher

在Neo4j Browser中可以直接输入命令

CREATE (n:Node {id:1, name:'Alice', type:'Person', industry:'software'})

2. Py2neo

# 创建节点
a = Node("Node", id=1, name="Alice", type="Person", industry="software")
graph.create(a)
b = Node("Node", id=2, name="Bom", type="Person", industry="hardware")
graph.create(b)

添加关系

1. Cypher

MATCH (a:Node),(b:Node)
WHERE a.name = 'Alice' AND b.name = 'Bom'
CREATE (a)-[r:KNOWS] -> (b)
RETURN r

2. Py2neo

这里的a,b是承接上一部分的添加节点的代码

# 创建关系
rel = Relationship(a, "KNOWS", b)
graph.create(rel)

批量添加

本人测试下来,这两种方法,后者速度更快

1. Cypher

这边的文件得放在neo4j文件夹下的import文件夹里
node

LOAD CSV WITH HEADERS FROM 'file:///nodes.csv' AS row
CREATE (n:Node {id: row.id, name: row.name, type: row.type, industry: row.industry});

relation

LOAD CSV WITH HEADERS FROM 'file:///links.csv' AS row
MATCH (source:Node {id: row.source}), (target:Node {id: row.target})
MERGE (source)-[r:RELATIONSHIP {type: row.relation}]->(target);

2. Py2neo

node

import pandas as pd
from tqdm import tqdm# 读取CSV文件
df = pd.read_csv("path/to/your/nodes.csv")# 使用tqdm显示进度条
for index, row in tqdm(df.iterrows(), total=df.shape[0]):# 创建节点,这里假设CSV有'name', 'type', 'industry'列node = Node("Node", id=row['id'], name=row['name'], type=row['type'], industry=row['industry'])# 将节点添加到图中graph.create(node)

relation

# 读取关系CSV文件
df_relations = pd.read_csv("path/to/your/relations.csv")for index, row in df_relations.iterrows():source_node = matcher.match("Node", id=row['source']).first()target_node = matcher.match("Node", id=row['target']).first()if source_node and target_node:rel = Relationship(source_node, row['relation'], target_node)graph.create(rel)

查询

1. Cypher

MATCH (n:Node) 
WHERE n.industry = 'software' 
RETURN n

2. Py2neo

# 查询所有类型为"Person"的节点
query = "MATCH (n:Node) WHERE n.industry = 'software' RETURN n"
nodes = graph.run(query)
for node in nodes:print(node)

更新

1. Cypher

MATCH (n:Node {name: 'Alice'})
SET n.industry = 'IT'
RETURN n

2. Py2neo

# 查找名为Alice的节点并更新其行业
alice = matcher.match("Node", name="Alice").first()
if alice:alice['industry'] = 'IT'graph.push(alice)

删除

1. Cypher

MATCH (n:Node)-[r:KNOWS]->()
DELETE r

2. Py2neo

方法一:查询节点后删除

# 删除名为Bom的节点
bom = graph.nodes.match("Node", name="Bom").first()
graph.delete(bom)

方法二:运行CYPHER语句

#删除特定属性的节点,例如删除所有industry为"hardware"的节点
query = "MATCH (n:Node {industry: 'hardware'}) DELETE n"
graph.run(query)# 删除特定类型的关系,例如删除所有KNOWS关系
query = "MATCH ()-[r:KNOWS]-() DELETE r"
graph.run(query)

如果有帮助到你,能点个赞嘛!!谢谢!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.bcls.cn/Xxrj/3296.shtml

如若内容造成侵权/违法违规/事实不符,请联系编程老四网进行投诉反馈email:xxxxxxxx@qq.com,一经查实,立即删除!

相关文章

MFC 配置Halcon

1.新建一个MFC 工程,Halcon 为64位,所以先将工程改为x64 > VC 目录设置包含目录和库目录 包含目录 库目录 c/c ->常规 链接器 ->常规 > 链接器输入 在窗口中添加头文件 #include "HalconCpp.h" #include "Halcon.h"…

[Java基础揉碎]idea工具

目录 调整导航菜单区域的字体大小: 调整代码区域的字体大小: 代码字体变粗: 调整颜色主题: 调整全局字符编码(Project Encoding:项目的字符编码) : 常用的快捷键(使用的windows快捷键主题): ​编辑 ​编辑 ​编辑 自己配置:​编辑 模版快捷键: 导入该行需要的类:…

云HIS系统源码,基于云计算技术的B/S架构的云HIS系统,二甲医院信息管理系统

云HIS系统源码,采用云端SaaS服务的方式提供 基于云计算技术的B/S架构的云HIS系统,采用云端SaaS服务的方式提供,使用用户通过浏览器即能访问,无需关注系统的部署、维护、升级等问题,系统充分考虑了模板化、配置化、智能…

3DIoUMatch: Leveraging IoU Prediction for Semi-Supervised 3D Object Detection

3DIoUMatch: Leveraging IoU Prediction for Semi-Supervised 3D Object Detection 论文链接:https://arxiv.org/pdf/2012.04355.pdf 代码链接:https://github.com/yezhen17/3DIoUMatch 作者单位:Stanford University等 发表平台:…

Windows环境下使用SSH的开源图形化SFTP工具客户端 简介和基本使用

在Windows环境下,有许多开源的图形化SFTP工具客户端可以使用,其中比较受欢迎的是WinSCP和FileZilla。下面我将分别介绍这两个工具的基本信息和使用方法。 WinSCP WinSCP是一个Windows环境下使用的开源图形化SFTP客户端,它也支…

应用管理中心架构的设计与实现

应用管理中心在现代软件开发中扮演着重要角色,它能够帮助开发团队有效管理和监控各种应用的运行情况。本文将介绍如何设计和实现一个高效、可靠的应用管理中心架构,以提升开发团队的工作效率和系统稳定性。 1. 架构概述 - 介绍应用管理中心的整体架构…

ACM题解Day6 | 质数素数模块 | 完数难题

学习目标: 博主介绍: 27dCnc 专题 : 数据结构帮助小白快速入门算法 👍👍👍👍👍👍👍👍👍👍👍👍 ☆*: .。. o(≧▽…

2024.2.23 C++QT 作业

思维导图 练习题 1>简单实现闹钟播报,设置时间,当系统时间与设置时间相同时播报语音5次,然后停止。如果设置时间小于当前系统时间,则弹出消息提示框,并清空输入框。 #include "widget.h" #include &quo…

【stm32】hal库学习笔记-UART/USART串口通信(超详细!)

【stm32】hal库学习笔记-UART/USART串口通信 hal库驱动函数 CubeMX图形化配置 导入LCD.ioc RTC设置 时钟树配置 设置LSE为RTC时钟源 USART设置 中断设置 程序编写 编写主函数 /* USER CODE BEGIN 2 */lcd_init();lcd_show_str(10, 10, 16, "Demo12_1:USART1-CH340&q…

【前端素材】推荐优质后台管理系统Acara平台模板(附源码)

一、需求分析 后台管理系统在多个层次上提供了丰富的功能和细致的管理手段,帮助管理员轻松管理和控制系统的各个方面。其灵活性和可扩展性使得后台管理系统成为各种网站、应用程序和系统不可或缺的管理工具。 后台管理系统是一种用于管理和控制网站、应用程序或系…

B站UP视频播放数据分析之北冥乘海生

【背景介绍】 几年前做过类似的分析,但是B站数据加密了,刚好最近在用selenium,就顺手用它爬一下数据。 df pd.read_excel("北冥乘海生_5.2万_output.xlsx") df.head() 打开B站,刚好就看到这个UP更新推荐,…

SpringBoot+Vue+MySQL:图书管理系统的技术革新

✍✍计算机编程指导师 ⭐⭐个人介绍:自己非常喜欢研究技术问题!专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目:有源码或者技术上的问题欢迎在评论区一起讨论交流! ⚡⚡ Java实战 |…

【stm32】hal库-双通道ADC采集

【stm32】hal库-双通道ADC采集 CubeMX图形化配置 程序编写 /* USER CODE BEGIN PV */ #define BATCH_DATA_LEN 1 uint32_t dmaDataBuffer[BATCH_DATA_LEN]; /* USER CODE END PV *//* USER CODE BEGIN 2 */lcd_init();lcd_show_str(10, 10, 24, "Demo14_4:ADC1 ADC2 S…

链表之“无头单向非循环链表”

目录 ​编辑 1.顺序表的问题及思考 2.链表 2.1链表的概念及结构 2.2无头单向非循环链表的实现 1.创建结构体 2.单链表打印 3.动态申请一个节点 3.单链表尾插 4.单链表头插 5.单链表尾删 6.单链表头删 7.单链表查找 8.单链表在pos位置之前插入x 9.单链表删除pos位…

【DDD】学习笔记-发布者—订阅者模式

在领域设计模型中引入了领域事件,并不意味着就采用了领域事件建模范式,此时的领域事件仅仅作为一种架构或设计模式而已,属于领域设计模型的设计要素。在领域设计建模阶段,如何选择和设计领域事件,存在不同的模式&#…

汽车常识网:电脑主机如何算功率的计算方法?

今天汽车知识网就给大家讲解一下如何计算一台主机的功率。 它还会解释如何计算计算机主机所需的功率? ? (如何计算电脑主机所需的功率)进行说明。 如果它恰好解决了您现在面临的问题,请不要忘记关注本站。 让我们现在就…

86、移除推理路径上的所有内存操作

动态申请内存的影响,前两节已经介绍过了,细心的朋友可能会发现,在使用 C++实现的 resnet50 代码中,还存在一处动态申请内存的操作。 那就是对于每一层的输入或输出 feature map 数据进行内存申请,比如在 3rd_preload/ops/conv2d.cc 文件中,卷积的计算中存在对于输出 fea…

小世界网络:直径、分形、同配性

1.小世界网络特点 —— 网络直径接近于网络中节点数量的自然对数 2.小世界分形网络 —— 移除弱链接的小世界网络 3.同配性分析 —— Pearson相关系数、邻居相关度 在宏观层面上,关注平均度、度分布和聚类等全局结构特征的影响。更高的平均度被认为会导致更…

数据库应用:kylin 部署 达梦数据库DM8

目录 一、实验 1.环境 2.部署前规划 3.部署达梦数据库DM8 4.创建数据库及数据库事例管理 5.达梦数据库的基本操作 二、问题 1.xhost命令报错 2.执行安装程序DMInstall.bin 报错 3.解压安装程序报错 4.安装程序找不到文件 5.图像化界面打不开 6.安装内存太小 7.打开…

C#版字节跳动SDK - SKIT.FlurlHttpClient.ByteDance

前言 在我们日常开发工作中对接第三方开放平台,找一款封装完善且全面的SDK能够大大的简化我们的开发难度和提高工作效率。今天给大家推荐一款C#开源、功能完善的字节跳动SDK:SKIT.FlurlHttpClient.ByteDance。 项目官方介绍 可能是全网唯一的 C# 版字…
推荐文章