Neo4j常见语句-delete

delete用法(DELETE 操作用于移除图数据库中的节点和关系。与其他数据库不同,Neo4j 的删除操作需要考虑节点与关系的依赖关系(不能直接删除有关联关系的节点))

(1)基本语法

bash 复制代码
DELETE <node_or_relationship> [, <node_or_relationship>]...

(2)核心规则:

bash 复制代码
  不能直接删除有关联关系的节点,需先删除关系
  可同时删除多个节点或关系
  支持与 MATCH 结合精准定位删除目标

(3)删除关系

a.删除单个关系

bash 复制代码
// 删除吴京和成龙之间的朋友关系
MATCH (w:Star {name: "吴京"})-[r:friend]-(c:Star {name: "成龙"}) 
DELETE r

b.按类型删除关系

bash 复制代码
// 删除所有"合作"类型的关系
MATCH ()-[r:COOPERATED_WITH]-()
DELETE r

c.删除带条件的关系

bash 复制代码
// 删除2010年前建立的朋友关系
MATCH ()-[r:FRIEND {since: < 2010}]-()
DELETE r

(4)删除节点

a. 删除孤立节点(无关系的节点)

bash 复制代码
// 删除名为"张三"(张三没有任何关系),结果为成功
MATCH (n:Person {name: "张三"})
DELETE n

// 陈奕迅因为和其他人有关系,所以下面语句执行不成功
MATCH (n:Singer {name: "陈奕迅"})
DELETE n

b.先删除关系再删除节点

bash 复制代码
 // 先删除陈奕迅的所有关系,再删除他的节点
MATCH (l:Singer {name: "陈奕迅"})
OPTIONAL MATCH (l)-[r]-()
DELETE r, l

c.批量删除节点(带标签)使用 DETACH DELETE

bash 复制代码
// 删除所有"歌手"类型的节点及其关系
MATCH (n:Singer)
DETACH DELETE n

注意:DETACH DELETE 会递归删除节点的所有入边和出边关系,使用时需谨慎!

(5)与 WHERE 结合精准删除

a.按属性条件删除

bash 复制代码
// 删除年龄大于60岁的演员节点
MATCH (a:Actor {age: > 60})
DETACH DELETE a

b.按关系数量删除

bash 复制代码
// 删除关系数少于3个的用户节点
MATCH (u:User)
WHERE size(()-[]-(u)) < 3
DETACH DELETE u

(6)批量删除操作(性能优化)

分段删除大数量数据

bash 复制代码
// 分批次删除1000个节点,避免内存溢出
MATCH (n:Person)
WITH n LIMIT 1000
DETACH DELETE n
相关推荐
羊羊小栈6 天前
基于GraphRAG的医疗健康知识诊断系统(Neo4j_大语言模型)
人工智能·语言模型·毕业设计·知识图谱·创业创新·neo4j·大作业
羊羊小栈10 天前
基于GraphRAG的地质矿产知识管理系统(Neo4j_大语言模型)
人工智能·语言模型·自然语言处理·毕业设计·neo4j·大作业
夜郎king11 天前
SpringBoot 整合 Neo4j 实战:从零搭建经典小说知识图谱完整方案
spring boot·知识图谱·neo4j
羊羊小栈12 天前
基于知识图谱(Neo4j)和大语言模型(LLM)的图检索增强(GraphRAG)的数控车床主轴系统故障诊断智能问答系统
人工智能·语言模型·毕业设计·知识图谱·创业创新·neo4j·大作业
_Rookie._13 天前
neo4j图形数据库 -基础语法
neo4j
星川皆无恙13 天前
基于BERT+LSTM+CRF与知识图谱的医疗智能问答系统实战:Neo4j图数据库+实体识别+意图分析完整项目
数据库·人工智能·深度学习·bert·lstm·知识图谱·neo4j
飞行家贞贞15 天前
Windows 安装 Neo4j(2025最新·极简)
neo4j
ins_lizhiming16 天前
多模态+neo4j+langchain构建知识图谱问答
langchain·知识图谱·neo4j
qq_3564086617 天前
Neo4j RPM 安装与多实例配置说明
neo4j
codefan※18 天前
干掉幻觉实战:如何构建企业级知识图谱增强 RAG
人工智能·大模型·llm·知识图谱·neo4j·rag·graphrag