图数据库Neo4j学习三——cypher语法总结

1MATCH

1.1作用

MATCH是Cypher查询语言中用于从图数据库中检索数据的关键字。它的作用是在图中查找满足指定条件的节点和边,并返回这些节点和边的属性信息。
在MATCH语句中,通过节点标签和边类型来限定查找范围,然后通过WHERE语句来筛选符合条件的节点和边。最后,通过RETURN语句返回查询结果中的属性信息。

1.2语法规则

MATCH (node1:Label1)-[edge:RELATIONSHIP]->(node2:Label2)
WHERE <condition>
RETURN <expression>
  1. Label1/ Label2表示节点的标签
  2. node1和node2是节点变量,可以用来引用节点的属性信息
  3. RELATIONSHIP表示边的类型
  4. edge是边变量,可以用来引用边的属性信息
  5. 是可选的查询条件,可以用来筛选满足条件的节点和边
  6. 是要返回的属性信息

在MATCH语句中,通过节点标签和边类型来限定查找范围,然后通过条件语句来筛选符合条件的节点和边。最后,通过RETURN语句返回查询结果中的属性信息。

1.3查询示例

假设我们有一个拥有Person和City两种标签的图数据库,其中Person节点有name、age和gender属性,City节点有name和population属性,它们之间的关系是Person节点居住在City节点中。我们要查找居住在人口大于100万的城市中女性的姓名和年龄。

MATCH (person:Person)-[:LIVES_IN]->(city:City)
WHERE city.population > 1000000 AND person.gender = 'F'
RETURN person.name, person.age

2OPTIONAL MATCH

2.1作用

在Cypher中,OPTIONAL MATCH用于查找可能匹配但不是必须的模式。这意味着,如果匹配失败或者找不到匹配的节点、关系或路径,OPTIONAL MATCH语句不会导致整个查询失败。相反,它将返回一个空结果。

2.2语法规则

OPTIONAL MATCH (node1:Label1)-[edge:RELATIONSHIP]->(node2:Label2)

2.3查询示例

//查找节点及其关系,如果关系不存在则返回空结果
MATCH (a:User)
OPTIONAL MATCH (a)-[r:RELATION]->(b)
RETURN a, r, b

例如如下所示,我们当我们使用OPTIONAL MATCH (a)-[r:RELATION]->(b) ,查询时,由于这里的RELATION是可选的匹配,因此,该关系就是,有就返回,没有就返回null,但是对于 (a:User) 则会全量返回,而对于 (b) 而言,因为b节点是通过关系查找的,因此如果关系不存在,那么这里的b节点一样也返回null。
在这里插入图片描述
提问:明明只有西子->念念、西子->老司、老司->念念这三个关系为RELATION,为什么上图中把西子->小跟班的老公关系也带出来?

这里其实不是RELATION查询出来的,而是MATCH (a:User)中,包含了西子,和小跟班,西子的老公是小跟班,然后用Neo4j来默认渲染上的拓扑节点。

我们实际查看数据的时候,可以看到返回的table中,西子和小跟班之间是没有找到关系,这是因为西子和小跟班之间的关系是老公,不是RELATION,所以用RELATION查询,是没有关系的,但是Neo4j在绘制拓扑图的时候会按照老公的关系,进行绘制。

这里我们做两个试验查询即可

//查询西子和小跟班,并没有查询他们的关系,返回的实际数据中,也没有两人的关系,但是确实neo4j绘制了拓扑图
MATCH (a:User{userName:'小跟班'}),(b:User{userName:'西子'}) RETURN a,b

在这里插入图片描述
在这里插入图片描述
而小跟班和念念没有建立关系,因此把西子改成念念以后,他们就变成两个孤立的点
在这里插入图片描述
因此得出一个结论,当neo4j返回的节点A和B,如果节点A和B本身具有关系,那么neo4j会自动把关系给补上

这里我们返回名称,用表格的关系来查看,就能看到如下所示,没有的值则是null,我们可以使用**type()**这个方法来查看关系类型

//查找节点及其关系,如果关系不存在则返回空结果
MATCH (a:User)
OPTIONAL MATCH (a)-[r:RELATION]->(b)
RETURN a.userName,type(r),r.nane, b.userName

在这里插入图片描述

2.4对比MATCH

OPTIONAL MATCH查询比MATCH多了一个OPTIONAL,那么我们把OPTIONAL删除掉来看看效果

//查找节点及其关系,如果关系不存在则返回空结果
MATCH (a:User) OPTIONAL MATCH (a)-[r:RELATION]->(b) RETURN a, r, b

//如果我们把OPTIONAL去掉,那么会发生什么效果?
MATCH (a:User) MATCH (a)-[r:RELATION]->(b) RETURN a, r, b

不难发现,只保留了RELATION关系的节点,没有RELATION关系的节点都没了
在这里插入图片描述
同样的查看表格数据,我们发现,确实只有RELATION,也就是有就有,没有就没有,没有就不返回了,由于没有返回节点,因此neo4j也没办法使用默认关系来绘制关系图

MATCH (a:User) MATCH (a)-[r:RELATION]->(b) RETURN a.userName,type(r),r.nane, b.userName

在这里插入图片描述

3RETURN

3.1作用

在Neo4j中使用Cypher查询语言,RETURN 关键字用于指定查询的结果集。查询的结果集可以是节点、关系、属性或一组这些元素的组合。

查询中的 RETURN 子句指定了查询返回的结果,可以返回节点、关系、属性、子图等。例如,可以使用 RETURN 显示特定节点的属性,也可以使用 RETURN 显示已匹配的节点和关系的子图。

使用 RETURN 子句的查询会返回一个结果集,这个结果集可以在Neo4j中进行进一步的处理,如排序、筛选、分组等。同时,RETURN 子句也可以与其他Cypher子句一起使用,如 MATCH 和 WHERE 等,以实现更复杂的查询操作。

3.2语法规则

RETURN <expression>
显示所有节点
MATCH (n) RETURN n

显示特定节点和它的标签
MATCH (n:Label) RETURN n, labels(n)

显示节点、关系和属性
MATCH (n)-[r]->(m) RETURN n, r, m

返回最短路径
MATCH p=shortestPath((a)-[r:REL_TYPE*]->(b)) RETURN p

显示节点计数
MATCH (n) RETURN count(n)

在Cypher中,RETURN 还允许你选择使用聚合函数,如 COUNT,SUM,MIN,MAX 和 AVG 等。

4WITH

4.1作用

在Neo4j中,WITH 关键字用于将查询结果传递到下一个查询中,并将其作为输入数据。WITH 关键字可以将查询分为多个部分,并允许在这些部分之间传递数据。

4.2使用场景

WITH 子句通常用于以下几种情况:
1为表达式求值结果引入新变量

MATCH (george {name: 'George'})<--(otherPerson)
WITH otherPerson, toUpper(otherPerson.name) AS upperCaseName
WHERE upperCaseName STARTS WITH 'C'
RETURN otherPerson.name

2查询分割:您可以使用WITH子句将一个查询分成几个部分,以便执行更复杂的操作。
例如,以下查询将找到所有与Alice有共同朋友的人,然后计算每个人有多少个共同朋友

MATCH (alice:Person {name: 'Alice'})-[:FRIEND]->(commonFriend:Person)<-[:FRIEND]-(person:Person)
WITH person, count(commonFriend) as numCommonFriends
RETURN person.name, numCommonFriends

3聚合:WITH子句还可以用于聚合数据。
例如,以下查询将计算每个标签的出现次数:

MATCH (n)
UNWIND labels(n) as label
WITH label, count(*) as count
RETURN label, count

在WITH子句中,还可以使用DISTINCT关键字来确保结果集中没有重复项,以及ORDER BY子句来对结果集进行排序

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/48085.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

解决VScode下载太慢的问题记录

最近突然想重新下载vscoded便携免安装版&#xff0c;发现下载很慢&#xff0c;于是乎查询一下&#xff0c;以便记录 下载地址 VScode官方网站&#xff1a; https://code.visualstudio.com/ 根据个人的需求选择下载&#xff0c;页面加载下载需要等一会&#xff0c; 然后就会…

kotlin高阶函数

kotlin高阶函数 函数式API:一个函数的入参数为Lambda表达式的函数就是函数式api 例子: public inline fun <T> Iterable<T>.filter(predicate: (T) -> Boolean): List<T> {return filterTo(ArrayList<T>(), predicate) }上面这段函数: 首先这个函…

使用EM算法完成聚类任务

EM算法&#xff08;Expectation-Maximization Algorithm&#xff09;是一种基于迭代优化的聚类算法&#xff0c;用于在无监督的情况下将数据集分成几个不同的组或簇。EM算法是一种迭代算法&#xff0c;包含两个主要步骤&#xff1a;期望步骤&#xff08;E-step&#xff09;和最…

态势标绘专题介绍

介绍 这个专栏是专门针对基于Cesium来实现态势标绘的专题专栏,专栏主要实现了30余种态势几何形状的标绘和编辑、文本的标绘和编辑、图片的标绘和编辑以及简单模型的标绘,同时支持标绘结果的导出以及导入。包括最终编写成的一个完整的Vue3.2+TS+Cesium1.107.2的标绘组件。专栏…

Java JVM虚拟机内部体系结构

JVM(Java虚拟机)是一个抽象机器。 它是一个提供可以执行Java字节码的运行时环境的规范。JVM可用于许多硬件和软件平台(即JVM是平台相关的)。 什么是JVM&#xff1f; JVM(Java虚拟机)是&#xff1a; 指定Java虚拟机的工作的规范。 但实现提供程序是独立的选择算法。 其实现是由…

【Hive实战】Hive的压缩池与锁

文章目录 Hive的压缩池池的分配策略自动分配手动分配隐式分配 池的等待超时Labeled worker pools 标记的工作线程&#xff08;自定义线程池&#xff09;Default pool 默认池Worker allocation 工作线程的分配 锁Turn Off ConcurrencyDebuggingConfigurationhive.support.concur…

如何跳出Java中的多层嵌套循环?

在Java中&#xff0c;要跳出多层嵌套循环&#xff0c;可以使用带有标签的break语句。通过在外层循环前加上一个标签&#xff0c;然后在内层循环中使用break语句后跟标签名称&#xff0c;可以实现跳出多层循环的目的。 以下是使用标签和break语句跳出多层嵌套循环的示例代码&…

BUG:pm2启动verdaccio报错:Invalid or unexpected toke

输入命令&#xff1a; pm2 state verdaccio 问题描述&#xff1a; pm2 logs verdaccio报错翻译&#xff1a;数据格式错误 导致我呢提原因&#xff0c;没有找到运行文件&#xff0c; 发现问题&#xff1a;因为命令默认查找verdaccio是去系统盘查找。 解决方式 1&#xff1a;…

Hadoop_HDFS_常见的文件组织格式与压缩格式

参考资料 1. HDFS中的常用压缩算法及区别_大数据_王知无_InfoQ写作社区 2. orc格式和parquet格式对比-阿里云开发者社区 3.Hadoop 压缩格式 gzip/snappy/lzo/bzip2 比较与总结 | 海牛部落 高品质的 大数据技术社区 4. Hive中的文件存储格式TEXTFILE、SEQUENCEFILE、RCFILE…

【家庭公网IPv6】

家庭公网IPv6 这里有两个网站&#xff1a; 1、 IPV6版、多地Tcping、禁Ping版、tcp协议、tcping、端口延迟测试&#xff0c;在本机搭建好服务器后&#xff0c;可以用这个测试外网是否可以访问本机&#xff1b; 2、 IP查询ipw.cn&#xff0c;这个可以查询本机的网络是否IPv6访问…

Java面向对象 - 常用类——Object类

什么是Object类 Java中有一个比较特殊的类&#xff0c;就是 Object类&#xff0c;它是所有类的父类&#xff0c;如果一个类没有使用extends关键字明确标识继承另外一个类&#xff0c;那么这个类就默认继承 Object类。因此&#xff0c;Object 类是 Java 类层中的最高层类&#x…

c++11 标准模板(STL)(std::basic_filebuf)(七)

定义于头文件 <fstream> template< class CharT, class Traits std::char_traits<CharT> > class basic_filebuf : public std::basic_streambuf<CharT, Traits> std::basic_filebuf 是关联字符序列为文件的 std::basic_streambuf 。输入序…

基于 STM32+FPGA 的通用工业控制器设计(一)系统方案设计

本章首先介绍了现有 PLC 系统的概况&#xff0c;然后提出了本文设计的通用工业控制器的 整体方案架构&#xff0c;分析了硬件和软件上需要实现的功能&#xff0c;最后对各部分功能进行分析并提 出具体的实现方案。 2.1 PLC 系统简介 可编程逻辑控制器&#xff08; Progra…

RocketMQ, Dashboard, 控制台安装

文章说明 本文主要说明RocketMQ的控制台&#xff08;Dashboard&#xff09;的安装过程。工作中一直用的是别人装好的&#xff0c;这次终于自己亲手装了一遍。 由于每次都要启动三个应用&#xff0c;比较烦&#xff0c;于是我写了一键启动脚本&#xff0c;分享给大家。这个脚本…

7. Spring Boot 配置文件

目录 1. 配置文件作用 2. 配置文件格式 3. properties 配置文件说明 3.1 properties 基本语法 3.2 读取配置文件 3.3 缺点 4. yml 配置文件说明 4.1 properties 基本语法 4.2 读取配置文件 4.3 yml 配置不同的数据类型 布尔值 整数值 null 值 配置对象 配置集合 …

国产化 | 记一次基于达梦创建数据库模式思考过程

开篇 首先&#xff0c;我们先来了解一下达梦数据库中用户与模式的概念&#xff0c;以及用户与模式之间的关系。 用户&#xff1a;主要是用来登录连接数据库&#xff0c;以及操作数据库对象等等。 模式&#xff1a;数据库中相关对象的集合。 关系&#xff1a;用户&#xff0…

基于VUE3+Layui从头搭建通用后台管理系统(前端篇)六:后台主页功能实现下

一、本章内容 接上一章,继续实现后端主页内容,主要实现工具栏对应相关内容的实现,包括系统消息、系统公告、全屏切换、语言切换、主题切换等。 1. 详细课程地址: 待发布 2. 源码下载地址: 待发布 二、界面预览 三、开发视频 基于VUE3+Layui从头搭建通用后台管理系统合集…

Elasticsearch:使用 Elasticsearch ingest pipeline 丰富数据

在我之前的文章&#xff1a; Elasticsearch&#xff1a;如何使用 Elasticsearch ingest 节点来丰富日志和指标 Elasticsearch&#xff1a;enrich processor &#xff08;7.5发行版新功能&#xff09; 我有详细描述如何使用 ingest pipeline 来丰富数据。在今天的文章中里&am…

【已解决】 Celery 报错:AttributeError: ‘EntryPoints‘ object has no attribute ‘get‘

【已解决】 Celery 报错&#xff1a;AttributeError: EntryPoints object has no attribute get 1、起因2、实验环境3、解决方案 1、起因 今天闲来无事学习 Celery 分布式任务队列&#xff0c;写好代码发布并执行&#xff0c;报错了 AttributeError: EntryPoints object has n…