Neo4j 基础教程(二):Cypher CRUD 完全指南

Neo4j 基础教程(二):Cypher CRUD 完全指南

环境:macOS + Neo4j Browser,此篇简单介绍Cypher的CRUD操作。


准备工作

确认 Neo4j 正在运行,浏览器打开 http://localhost:7474


基础查询:MATCH

查询所有节点

cypher 复制代码
MATCH (n) RETURN n

按标签查询

cypher 复制代码
// 查找所有 Person 节点
MATCH (p:Person) RETURN p

// 查找特定属性
MATCH (p:Person {name: 'Alice'}) RETURN p

带条件的查询

cypher 复制代码
// WHERE 子句
MATCH (p:Person)
WHERE p.age >= 25
RETURN p.name, p.age

// 多条件
MATCH (p:Person)
WHERE p.age > 25 AND p.name STARTS WITH 'A'
RETURN p

限定返回数量

cypher 复制代码
MATCH (p:Person) RETURN p LIMIT 10

创建:CREATE

创建节点

cypher 复制代码
// 无标签节点
CREATE (n)

// 带属性
CREATE (p:Person {name: 'Charlie', city: 'Beijing'})

// 一次性创建多个节点
CREATE (a:Dev {lang: 'Python'}),
       (b:Dev {lang: 'JavaScript'}),
       (a)-[:WORKS_WITH]->(b)

创建关系

cypher 复制代码
// 假设 Alice 和 Bob 已存在,现在创建关系
MATCH (a:Person {name: 'Alice'}), (b:Person {name: 'Bob'})
CREATE (a)-[:KNOWS {year: 2021}]->(b)

带变量的 CREATE

cypher 复制代码
// 创建并返回节点
CREATE (p:Person {name: 'Diana', role: 'Designer'})
RETURN p

更新:SET

更新节点属性

cypher 复制代码
// 精确匹配后更新
MATCH (p:Person {name: 'Alice'})
SET p.age = 31, p.city = 'Shanghai'
RETURN p

添加额外属性

cypher 复制代码
MATCH (p:Person {name: 'Alice'})
SET p.email = 'alice@example.com'

使用 map 更新

cypher 复制代码
MATCH (p:Person {name: 'Bob'})
SET p += {phone: '13800138000', country: 'China'}

删除:DELETE / REMOVE

删除关系

cypher 复制代码
// 先查再删
MATCH (a:Person)-[r:KNOWS]->(b:Person)
WHERE a.name = 'Alice' AND b.name = 'Bob'
DELETE r

删除节点

cypher 复制代码
// 删除节点(需先删除关联关系)
MATCH (p:Person {name: 'Diana'})
DETACH DELETE p

⚠️ DETACH DELETE 会同时删除所有关系,最安全

移除属性

cypher 复制代码
// 移除某个属性(用 REMOVE)
MATCH (p:Person {name: 'Alice'})
REMOVE p.age

移除标签

cypher 复制代码
MATCH (p:Person)
REMOVE p:Person

MERGE:防重复插入

cypher 复制代码
// 如果节点已存在则不重复创建
MERGE (p:Person {name: 'Alice'})
RETURN p

// 确保关系存在,不重复创建
MATCH (a:Person {name: 'Alice'}), (b:Person {name: 'Bob'})
MERGE (a)-[r:KNOWS]->(b)
RETURN r

💡 MERGE = MATCH + CREATE,是插入数据的最佳实践


进阶查询

路径查询

cypher 复制代码
// 查找 Alice 的二级联系人
MATCH (a:Person {name: 'Alice'})-[:KNOWS]->(friend)-[:KNOWS]->(fof)
RETURN friend.name, fof.name

聚合函数

cypher 复制代码
// 统计每种标签的节点数量
MATCH (n)
RETURN labels(n) AS label, count(n) AS count
ORDER BY count DESC

ORDER BY / SKIP

cypher 复制代码
MATCH (p:Person)
RETURN p.name, p.age
ORDER BY p.age DESC
SKIP 2 LIMIT 5

实战小练习:构建社交关系图

cypher 复制代码
// 清空数据
MATCH (n) DETACH DELETE n;

// 创建人物
CREATE
  (alice:Person {name: 'Alice', job: 'Engineer'}),
  (bob:Person {name: 'Bob', job: 'Designer'}),
  (carol:Person {name: 'Carol', job: 'Manager'}),
  (dave:Person {name: 'Dave', job: 'Engineer'}),
  (eve:Person {name: 'Eve', job: 'Analyst'});

// 创建关系
MATCH (a:Person {name:'Alice'}), (b:Person {name:'Bob'}) CREATE (a)-[:KNOWS]->(b);
MATCH (a:Person {name:'Bob'}), (c:Person {name:'Carol'}) CREATE (a)-[:KNOWS]->(c);
MATCH (a:Person {name:'Alice'}), (d:Person {name:'Dave'}) CREATE (a)-[:KNOWS]->(d);
MATCH (a:Person {name:'Carol'}), (e:Person {name:'Eve'}) CREATE (a)-[:KNOWS]->(e);
MATCH (a:Person {name:'Dave'}), (e:Person {name:'Eve'}) CREATE (a)-[:KNOWS]->(e);

练习题

  1. 查找所有工程师(Engineer)
  2. 查找 Alice 的直接好友
  3. 查找 Bob 通过一层关系能认识谁(二度人脉)
  4. 统计每个人认识多少人

快捷键备忘

操作 快捷键
执行查询 Ctrl+Enter / Cmd+Enter
格式化代码 Shift+Ctrl+F
清空编辑器 Ctrl+Delete

下一步

  • 教程三:数据建模与 Python/JavaScript 连接实战

相关推荐
格鸰爱童话2 天前
springboot3.2使用neo4j
springboot·neo4j
Yeats_Liao4 天前
智能感知低功耗设计:MCU上的AI异常检测与能效优化
人工智能·单片机·物联网·neo4j
wjykp5 天前
1.neo4j琐碎知识
数据库·neo4j
一个数据大开发5 天前
企业知识工程的三条路线:Neo4j 知识中台、Agent + Action 与本体原生 Runtime
大数据·python·neo4j
伊甸36 天前
Neo4j 常用语法速查(Cypher)
java·数据库·neo4j
独隅7 天前
用 Anaconda 驯服 AI 开发流:从数据预处理到模型部署的全链路环境标准化实战指南
人工智能·neo4j
哥本哈士奇7 天前
Neo4j笔记(五):查询的处理流程
neo4j
百年੭ ᐕ)੭*⁾⁾15 天前
docker使用neo4j
docker·容器·neo4j
金斗潼关16 天前
neo4j使用说明
neo4j
田井中律.18 天前
neo4j图数据库安装教程(windows)
数据库·neo4j