一、简介


Cypher语言是在学习Neo4j时用到数据库操作语言(DML),涵盖对图数据的增删改查,跟SQL有较大不同,本文仅记录一些要点备查


二、详述


1、基本概念

Neo4j中不存在表的概念,只有两类:节点(Node)和关联(Relation),可以简单理解为图里面的点和边,在数据查询中,节点一般用小括号(),关联用中括号[]。当然也隐含路径的概念,是用节点和关联表示的,如:(a)-[r]->(b),表示一条从节点a经关联r到节点b的路径

2、创建语句

1)创建节点

create (a) 创建空节点

create (a:Person) 创建标签(可以理解为类)为Person的节点

create (a:Person {name:'Kaine',age:28}) 创建标签为Person,属性name值为Kaine,属性age值为28的节点

2)创建关联

match (a),(b)

where a.name='Kaine' and b.name='Sharon'

create (a)-[r]->(b)

创建a节点和b节点的路径,此时变量r即代表关联,它也可以有标签

2、查询关键字

match:用来匹配一定模式,可以是简单的节点、关联,也可以是复杂的路径

where:用来限定条件,一般是限定match中的出现变量的属性

return:返回结果

start:开始节点,一般用于有索引的节点或者关联

3、基本查询样式

match ... where ... return ...

如果match有多个对象,用逗号隔开;

如果where有多个条件,用and连接;

如果return有多个变量,用逗号隔开

4、查询举例

match (n) return n 查询所有节点及关联

match (a)-[r]->(b) where a.name='Kaine' return a,b 查询属性name的值是Kaine的节点,及其所有关联节点

match (a)-[*1..3]->(b) where a.name='Kaine' return a,b 查询属性name值是Kaine的节点,及其所有距离为1到3的关联节点,

match (a)-[*2]->(b) where a.name='Kaine' and not (a)-[*1]->(b) return a,b 查询属性name的值是Kaine的节点,及其所有距离为2并且去除距离为1的节点。(在计算好友的好友时会用到,即如果a、b、c三个人都认识,如果仅计算跟a距离为2的人的时候会把b、c也算上,因为a->b->c,或者a->c->b都是通路)

注:关联的中括号内数字的含义

n 距离为n

..n 最大距离为n

n.. 最小距离为n

m..n 距离在m到n之间