Neo4j CQL语法

目录

0. 简述

CQL 代表密码查询语言。就像 Oracle 数据库有查询语言 SQL,Neo4j 有 CQL 作为查询语言。

1. 创建节点

创建单个节点

cql 复制代码
CREATE (node_name);

其中(;)是可选的。

创建多个节点

cql 复制代码
CREATE (node_name1),(node_name2)

创建带标签的节点

cql 复制代码
CREATE (node:label)

创建具有多个标签的节点(用冒号":"分隔)

cql 复制代码
CREATE (node:label1:label2:...labeln)

创建具有属性的节点(在"{ }"中指定这些属性,用逗号分隔)

cql: 复制代码
CREATE (node:label1{name:"zhangsan", year:1999, country:"China"})

验证:返回数据库中的所有节点

cql 复制代码
MATCH (n) RETURN n;

返回创建的节点

cql 复制代码
CREATE (node:label1{name:"zhangsan", year:1999, country:"China"}) RETURN node

2. 创建关系

首先在数据库中创建两个节点Dhawan和Ind,如下:

cql 复制代码
CREATE (Dhawan:player {name:"Shikar Dhawan", YOB:1985, POB:"Delhi})
CREATE (Ind:Country {name:"India"})

使用节点创建关系

在两节点间建立一个名为 BATSMAN_OF 的关系

cql 复制代码
CREATE (Dhawan)-[r:BATSMAN_OF]->(Ind)

最后,返回两个节点以查看创建的关系

cql 复制代码
RETURN Dhawan, Ind

使用节点和标签创建关系

cql 复制代码
MATCH (a:player), (b:Country) WHERE a.name="Shikar Dhawan" AND b.name = "India" CREATE (a)-[r:BATSMAN_OF]->(b) RETURN a,b

使用标签和属性创建关系

cql 复制代码
MATCH (a:player), (b:Country) WHERE a.name = "Shikar Dhawan" AND b.name = "India"
CREATE (a)-[r:BATSMAN_OF {Matches:5, Avg:90.75}]->(b) RETURN a,b

创建完整路径

cql 复制代码
CREATE p = (Node1 {properties})-[:Relationship_Type]-> (Node2 {properties})[:Relationship_Type]->(Node3 {properties}) RETURN p

3. 合并命令

MERGE 命令是 CREATE 命令和 MATCH 命令的组合。

Neo4j CQL MERGE 命令在图中搜索给定模式。如果存在,则返回结果。

如果它在图中不存在,那么它会创建一个新的节点/关系并返回结果。


首先,在数据库中创建两个标签为 Dhawan 和 Ind 的节点。创建从 Dhawan 到 Ind 的类型为"BATSMAN_OF"的关系,如下:

cql 复制代码
CREATE (Dhawan:player{name: "Shikar Dhawan", YOB: 1985, POB: "Delhi"}) 
CREATE (Ind:Country {name: "India"}) 
CREATE (Dhawan)-[r:BATSMAN_OF]->(Ind) 

将节点与标签合并

Neo4j 会验证是否存在具有给定标签的任何节点。如果没有,将创建当前节点。

cql 复制代码
MERGE (Jadeja:player) RETURN Jadeja

将节点与属性合并

cql 复制代码
MERGE (Jadeja:player {name: "Ravindra Jadeja", YOB: 1988, POB: "NavagamGhed"}) RETURN Jadeja 

合并关系

cql 复制代码
MATCH (a:Country), (b:Tournament) 
   WHERE a.name = "India" AND b.name = "ICC Champions Trophy 2013" 
   MERGE (a)-[r:WINNERS_OF]->(b) 
RETURN a, b

未完待续

相关推荐
七夜zippoe几秒前
# DolphinDB分区策略:RANGE分区详解
数据库·策略·分区·range·dolphindb
地球资源数据云12 分钟前
中国陆地生态系统主要植物功能特征空间分布数据
大数据·数据库·人工智能·机器学习
吠品19 分钟前
高性能JS数组操作:何时选用push、unshift、splice或扩展运算符?
linux·服务器·数据库
洛水水26 分钟前
【Redis入门】一篇详解Redis五大数据结构
数据结构·数据库·redis
woodykissme31 分钟前
日产汽车花键测绘,为什么总踩坑?
数据库·汽车·齿轮·渐开线花键
雨辰AI1 小时前
从 MySQL 迁移至人大金仓 V9 完整改造指南|分页 / 函数 / 语法兼容全部解决
java·开发语言·数据库·后端·mysql·政务
Chengbei111 小时前
AI大模型网关存在SQL注入、影响版本LiteLLM 1.81.16~1.83.7(CVE-2026-42208)
数据库·人工智能·sql·安全·web安全·网络安全·系统安全
zx2859634001 小时前
Laravel 9.x:全面升级与核心特性
数据库
努力努力再努力wz2 小时前
【MySQL进阶系列】一文打通事务机制:从锁、Undo Log 到 MVCC 与隔离级别
c语言·数据结构·数据库·c++·mysql·算法·github
PaperData2 小时前
2000-2025年《中国县域统计年鉴》pdf+excel版(附赠面板数据)
数据库·人工智能·数据分析·pdf·经管