当前位置: 首页 > news >正文

Neo4j常见语句-delete

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

DELETE <node_or_relationship> [, <node_or_relationship>]...

(2)核心规则:

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

(3)删除关系
a.删除单个关系

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

b.按类型删除关系

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

c.删除带条件的关系

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

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

// 删除名为"张三"(张三没有任何关系),结果为成功
MATCH (n:Person {name: "张三"})
DELETE n// 陈奕迅因为和其他人有关系,所以下面语句执行不成功
MATCH (n:Singer {name: "陈奕迅"})
DELETE n

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

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

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

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

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

(5)与 WHERE 结合精准删除
a.按属性条件删除

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

b.按关系数量删除

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

(6)批量删除操作(性能优化)
分段删除大数量数据

// 分批次删除1000个节点,避免内存溢出
MATCH (n:Person)
WITH n LIMIT 1000
DETACH DELETE n
http://www.lryc.cn/news/571740.html

相关文章:

  • 华为云Flexus+DeepSeek征文|一键部署华为云CCE容器高可用Dify平台的实践经验与思考
  • 部署并了解什么是openstack
  • 结合 STM32CubeMX 使用 FreeRTOS 实时操作系统
  • pyqt 简单条码系统
  • java充电桩源码获取,云快充源码、OCPP、互联互通协议源码实现SpringCloud+vue
  • 对抗性提示:进阶守护大语言模型
  • 使用 Elasticsearch 提升 Copilot 能力
  • Arduino入门教程:10、屏幕显示
  • aws各类服务器编号
  • 阿里云主机自动 HTTPS 证书部署踩坑实录
  • Day04_C语言基础数据结构重点复习笔记20250618
  • 28.行为型模式分析对比
  • linux 下 jenkins 构建 uniapp node-sass 报错
  • WPF学习(二)
  • 专题:2025信创产业新发展+AI趋势数字化研究报告|附30+份报告PDF汇总下载
  • 【OpenGL ES】不用GLSurfaceView,如何渲染图像
  • java学习笔记 IDEA的相关配置
  • 基于Android的打印系统的设计与实现
  • 深入解析 Java List 实现类的底层原理
  • 软件技术专业的出路在哪
  • 学习量子网络中的最佳路径
  • 华为云Flexus+DeepSeek征文 | 基于DeepSeek-R1强化学习的多模态AI Agent企业级应用开发实战:从理论到生产的完整解决方案
  • 使用 Visual Studio 创建安装包的完整指南
  • Saucer 页面嵌入使用举例
  • MySQL 8.0 OCP 题库完整版
  • 【Git】Git生产项目分支管理实战指南包含开发、测试、生产、bug修复和需求迭代
  • SHELL脚本(一)
  • 【微信小程序】4、SpringBoot整合WxJava生成小程序码
  • github为InfiniSynapse Docker提PR过程留档@Windows10
  • mysql 根据查询语句创建表语句