Cypher是Neo4j专门用于图数据库的查询语言,类似于Oracle数据库的SQL语言,是一种声明式查询语言,只需要用户描述需要执行什么动作(match、insert等),而不需要描述具体怎么做,需要注意的是,只有在商业版中,Cypher的查询语句编译器才会生成高性能的查询动作. 同时Cypher项目中又建立了一个支持Spark的项目,Cypher for Apache Spark
Neo4j里面提供了多种不同的访问方式,包括
- 通过一个HTTP API执行Cypher查询,并获取JSON格式的结果;
- 一种“非托管扩展”机制,允许你为Neo4j数据库编写自己的终结点;
- 通过一个高层Java API指定节点与关系的遍历;
- 通过一个低层的批量加载API处理海量初始数据的获取;
- 通过一个核心Java API直接访问节点与关系,以获得最大的性能;
首先需要介绍,Neo4j能够存储的图数据的类别,其中包括
- 节点名称(node-name) 和 节点标签名称(label-name)
- 节点的属性和属性值{properties-list}
- 联系名称(relationship-name) 和 联系标签(relationship-label-name)
- 联系的属性和属性值{properties-list}
节点是图中的实体,它可以保存任意数量的属性(键值对),同时通过标签进行标记,来表示在构建的具体领域中的不同角色. 联系提供了两个实体节点之间的,具名有向边,两个节点之间可以拥有任意数量的关联联系.
模式
同时在Cypher里面有一个很重要的概念,就是模式. 节点和关联关系组成特定的图结构模型,模式的描述形式可以是连续,也可以通过逗号间隔,在Neo4j里提供一下例子:
朋友的朋友: (user)-[:KNOWS]-(friend)-[:KNOWS]-(foaf)
查询最短距离: path = shortestPath( (user)-[:KNOWS*..]-(other) )
协同过滤 (user)-[:PURCHASED]->(product)<-[:PURCHASED]-()-[:PURCHASED]->(otherProduct)
树查询 (root)<-[:PARENT*]-(leaf:Category)-[:ITEM]->(data:Product
以上的模式描述可以被用到MATCH和CREATE语句里,用于匹配返回特定模式的数据
Node
表示为:
(<node1-name>:<node1-label-name>{<define-properties-list>})
Eg:
(video1:YoutubeVideo1{title:"Action Movie1",updated_by:"Abc",uploaded_date:"10/10/2010"})
联系
表示为:
[<relationship-label-name>:<relationship-name>{<define-properties-list>}]
Eg:

上图所示的,两个实体以及两个实体之间的联系以以下形式建模:
(video1:YoutubeVideo1{title:"Action Movie1",updated_by:"Abc",uploaded_date:"10/10/2010"})
-[movie:ACTION_MOVIES{rating:1}]->
(video2:YoutubeVideo2{title:"Action Movie2",updated_by:"Xyz",uploaded_date:"12/12/2012"})
关联关系的方向性通过 -[relation]-> 表示.
以下主要介绍Cypher中的一些主要语句
MARCH RETURN
- MATCH: 匹配相应的模式
- RETURN:返回数据
MATCH (john {name: 'John'})-[:friend]->()-[:friend]->(fof)
RETURN john.name, fof.name
以上匹配的模式就是节点名称为“john”的朋友的朋友是节点名称为“fof”,返回john和fof节点的name属性
CREATE、DELETE
CREATE
- 创建没有属性的节点
- 使用属性创建节点
- 在没有属性的节点之间创建关系
- 使用属性创建节点之间的关系
- 为节点或关系创建单个或多个标签
- 直接创建节点
CREATE (you:Person {name:"You"})
RETURN you
- 通过匹配模式创建节点
MATCH (you:Person {name:"You"})
CREATE (you)-[like:LIKE]->(neo:Database {name:"Neo4j" })
RETURN you,like,neo
MATCH (you:Person {name:"You"})
FOREACH (name in ["Johan","Rajesh","Anna","Julia","Andrew"] |
CREATE (you)-[:FRIEND]->(:Person {name:name}))
DELETE
待续…..
资料来源:
neo4j.com