本文概述
在Neo4j中, DELETE语句始终与MATCH语句一起使用以删除匹配的任何数据。 DELETE命令的使用位置与前面示例中使用RETURN子句的位置相同。
例子
MATCH (Kohli:person {Name: "Virat Kohli"}) DELETE Kohli

删除多个节点
你可以在单个语句中使用MATCH和DELETE命令删除多个节点。你只需要将不同的节点用一列分隔即可。
假设你具有以下两个节点:

使用以下命令删除两个节点。
MATCH (a:Student {Name: "Chris Grey"}), (b:Employee {Name: "Mark Twin"})
DELETE a, b

你会看到上面显示的消息, 两个节点都已删除。
删除所有节点
要从数据库中删除所有节点, 请不要使用任何过滤条件。
MATCH (n) DELETE n
注意:如果节点之间存在任何关系, 则以上语句无法删除它们。换句话说, 必须先删除任何关系, 然后再删除节点本身。否则, 你将收到以下错误消息。

有一种删除节点以及与该节点相关的所有关系的方法。
使用DETACH DELETE语句:
例:
MATCH (Kohli:player{name: "Virat Kohli"}) DETACH DELETE Kohli
输出

这将删除所有关系为” Virat Kohli”的节点” Kohli”。