Neo4j 第九篇:查询数据(Match)

Cypher使用match子句查询数据,是Cypher最基本的查询子句。在查询数据时,使用Match子句指定搜索的模式,这是从Neo4j数据库查询数据的最主要的方法。match子句之后通常会跟着where子句,向模式中添加过滤性的谓词,用于对数据进行过滤。在查询数据时,查询语句分为多个部分,with子句用于对上一个查询部分的结果进行处理,以输出到下一个查询部分。

一,节点查询

对节点进行查询,是查询graph的基本操作,节点具有标签和属性,Match查询不仅能够按照标签对节点进行查询,还能按照属性对节点进行查询。 当没有指定节点的标签或属性时,默认是选择节点全部的标签和属性。

1,查询所有节点

仅仅指定一个节点的模式,没有标签(Lable)和属性,表示查询所有的节点:

MATCH (n)
RETURN n

2,查询带有特定标签的节点

当模式中指定标签时,表示只查询带有特定标签的节点,有多个标签的节点,只要含有指定的标签,就成功匹配,绑定该节点。

MATCH (movie:Movie)
RETURN movie.title

3,查询相关的任意节点

指定一个节点,节点的name属性是‘Oliver Stone‘,查询跟该节点相关的其他节点:

MATCH (director { name: ‘Oliver Stone‘ })--(movie)
RETURN movie.title

4,查询相关的特定节点

指定一个节点,查询跟节点相关的节点,并指定相关节点的标签

MATCH (:Person { name: ‘Oliver Stone‘ })--(movie:Movie)
RETURN movie.title

二,基本关系的查询

对关系进行查询,关系的模式是由两个节点来决定的。

1,指定关系的方向来查询节点

对于标签是Person,并且name属性是‘Oliver Stone‘的节点,该节点指向另外一个节点movie:

MATCH (:Person { name: ‘Oliver Stone‘ })-->(movie)
RETURN movie.title

2,查询关系的类型

在查询关系时,可以在match子句中指定关系变量,后续子句可以引用该变量,例如,使用type()函数查看关系的类型:

MATCH (:Person { name: ‘Oliver Stone‘ })-[r]->(movie)
RETURN type(r)

3,匹配关系类型

在匹配关系时,可以指定关系的类型

MATCH (wallstreet:Movie { title: ‘Wall Street‘ })<-[:ACTED_IN]-(actor)
RETURN actor.name

3,匹配多种关系类型

在匹配关系时,可以指定多种关系的类型,只需要匹配其中任意一个关系类型就匹配成功

MATCH (wallstreet { title: ‘Wall Street‘ })<-[:ACTED_IN|:DIRECTED]-(person)
RETURN person.name

4,匹配关系类型,并指定关系变量

MATCH (wallstreet { title: ‘Wall Street‘ })<-[r:ACTED_IN]-(actor)
RETURN r.role

5,匹配多个关系

MATCH (charlie { name: ‘Charlie Sheen‘ })-[:ACTED_IN]->(movie)<-[:DIRECTED]-(director)
RETURN movie.title, director.name

三,匹配路径

路径是节点和关系交替组合构成的序列,图中必须满足路径指定的模式,才能返回路径中的元素。

1,对变长路径的查询

MATCH (martin { name: ‘Charlie Sheen‘ })-[:ACTED_IN*1..3]-(movie:Movie)
RETURN movie.title

2,路径变量

MATCH p =(actor { name: ‘Charlie Sheen‘ })-[:ACTED_IN*2]-(co_actor)
RETURN relationships(p),p

3,根据路径的属性进行匹配

MATCH p =(charlie:Person)-[* { blocked:false }]-(martin:Person)
WHERE charlie.name = ‘Charlie Sheen‘ AND martin.name = ‘Martin Sheen‘
RETURN p

参考文档:

Cypher Match

原文地址:https://www.cnblogs.com/ljhdo/p/10929702.html

时间: 2024-10-11 06:38:08

Neo4j 第九篇:查询数据(Match)的相关文章

NHibernate Linq查询 扩展增强 (第九篇)

NHibernate Linq查询 扩展增强 (第九篇) 在上一篇的Linq to NHibernate的介绍当中,全部是namespace NHibernate命名空间中的IQueryOver<TRoot, TSubType>接口提供的.IQueryOver<TRoot, TSubType>这个借口实际上会被翻译成条件查询(Criteria Queries). 实际上Linq to NHibernate更加强大.我们先引入命名空间NHibernate.Linq,这里面有Linq

mysql第四篇:数据操作之多表查询

mysql第四篇:数据操作之多表查询 一.多表联合查询 #创建部门 CREATE TABLE IF NOT EXISTS dept ( did int not null auto_increment PRIMARY KEY, dname VARCHAR(50) not null COMMENT '部门名称' )ENGINE=INNODB DEFAULT charset utf8; #添加部门数据 INSERT INTO `dept` VALUES ('1', '教学部'); INSERT INT

Python之路【第九篇】:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy

Python之路[第九篇]:Python操作 RabbitMQ.Redis.Memcache.SQLAlchemy Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度.Memcached基于一个存储键/值对的hashmap.其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信. Memc

100篇大数据文章[转]

摘要:PayPal高级工程总监Anil Madan写了篇大数据的文章,一共有100篇大数据的论文,涵盖大数据技术栈,全部读懂你将会是大数据的顶级高手. 开源(Open Source)用之于大数据技术,其作用有二:一方面,在大数据技术变革之路上,开源在众人之力和众人之智推动下,摧枯拉朽,吐故纳新,扮演着非常重要的推动作用.另一方面,开源也给大数据技术构建了一个异常复杂的生态系统.每一天,都有一大堆"新"框架."新"类库或"新"工具,犹如雨后春笋般涌

SQL Server索引 - 索引(物化)视图 &lt;第九篇&gt;

一.索引视图基本概念 索引视图实际上是一种将一组唯一值“物化”为群集索引形式的视图,所为物化就是几乎和表一样,其数据也是会存储一份的(会占用硬盘空间,但是查询速度快,例如可以将count(),sum()等值设在索引视图中).其优点是它在提取视图背后的信息方面提供了一个非常快的查找方法.在第一个索引(必须是针对一组唯一值的聚集索引)之后,通过使用来自第一个索引的聚集键作为参考点,SQL Server还能在视图上建立额外的索引.其限制如下: 视图必须使用SCHEMABINDING选项: 如果视图引用

第九篇 SQL Server安全透明数据加密

本篇文章是SQL Server安全系列的第九篇,详细内容请参考原文. Relational databases are used in an amazing variety of applications with connections from a dizzying array of clients over widely distributed networks,特别是互联网,使得数据几乎向任何人,任何地方开放.数据库可以包含相当大部分的人类知识,包括高度敏感的个人信息和关键数据.数据库的

Neo4j学习笔记(2)——数据索引

和关系数据库一样,Neo4j同样可以创建索引来加快查找速度. 在关系数据库中创建索引需要索引字段和指向记录的指针,通过索引可以快速查找到表中的行. 在Neo4j中,其索引是通过属性来创建,便于快速查找节点或者关系. 手动索引 先来说一下怎样创建手动索引. 创建索引采用显示创建,就像添加节点一样添加索引项,一个索引项标识的是一个节点或者关系的属性值. 索引项中除了包含属性值,还存储了对正在索引的属性具有特定值的一个或多个节点的引用. 以上是一个使用email属性作为键值指向节点的索引. 先通过下面

第九篇 Replication:复制监视器

本篇文章是SQL Server Replication系列的第九篇,详细内容请参考原文. 复制监视器允许你查看复制配置组件的健康状况.这一篇假设你遵循前八篇,并且你已经有一个合并发布和事务发布.启动复制监控器复制监视器不是SSMS的一部分,它是一个独立的可执行文件(SqlMonitor.exe).在一个标准的SQL Server安装中开始菜单下找不到复制监视器.启动复制监视器的最简单方法是:SSMS对象资源管理器下连接到发布服务器,右击你的发布选择"启动复制监视器",如图9.1所示:图

Python之路【第九篇】:Python基础(26)——socket server

socketserver Python之路[第九篇]:Python基础(25)socket模块是单进程的,只能接受一个客户端的连接和请求,只有当该客户端断开的之后才能再接受来自其他客户端的连接和请求.当然我 们也可以通过python的多线程等模块自己写一个可以同时接收多个客户端连接和请求的socket.但是这完全没有必要,因为python标准库已经为 我们内置了一个多线程的socket模块socketserver,我们直接调用就可以了,完全没有必要重复造轮子. 我们只需简单改造一下之前的sock