图数据库 Neo4j
现实中很多数据都是用图来表达的,比如社交网络中人与人的关系、地图数据、或是基因信息等等。
RDBMS 并不适合表达这类数据,而且由于海量数据的存在,让其显得捉襟见肘。
图数据库简介
NoSQL 数据库的兴起,很好地解决了海量数据的存放问题,图数据库也是 NoSQL 的一个分支,相比于 NoSQL 中的其他分支,它很适合用来原生表达图结构的数据。
Neo4j 是图数据库中一个主要代表,其开源,且用 Java 实现。
其有两种运行方式
- 一种是服务的方式,对外提供REST接口;
- 另外一种是嵌入式模式,数据以文件的形式存放在本地,可以直接对本地文件进行操作。
Neo4j简介
Neo4j 是一个高性能的,NOSQL图形数据库,它将结构化数据存储在网络上而不是表中。Neo4j也可以被看作是一个高性能的图引擎,该引擎具有成熟数据库的所有特性。程序员工作在一个面向对象的、灵活的网络结构下而不是严格、静态的表中——但是他们可以享受到具备完全的事务特性、企业级的数据库的所有好处。
Neo4 j因其嵌入式、高性能、轻量级等优势,越来越受到关注。
Neo4j数据结构
在一个图中包含两种基本的数据类型:Nodes(节点) 和 Relationships(关系)。Nodes 和 Relationships 包含key/value形式的属性。Nodes通过Relationships所定义的关系相连起来,形成关系型网络结构。
Neo4j适用于以下几个方面
1. 自带一套易于学习的查询语言(名为Cypher)
2. 不使用schema,因此可以满足你的任何形式的需求
3. 与关系型数据库相比,对于高度关联的数据(图形数据)的查询快速要快上许多
4. 它的实体与关系结构非常自然地切合人类的直观感受
5. 支持兼容ACID的事务操作
6. 提供了一个高可用性模型,以支持大规模数据量的查询,支持备份、数据局部性以及冗余
7. 提供了一个可视化的查询控制台,你不会对它感到厌倦的
Neo4j使用Demo
1.增(CREATE)
CREATE应用:
1. 创建没有属性的节点
2. 使用属性创建节点
3. 在没有属性的节点之间创建关系
4. 使用属性创建节点之间的关系
5. 为节点或关系创建单个或多个标签
例:创建带属性的节点
CREATE (emp:Employee{id:123,name:"Lokesh",sal:35000,deptno:10})
其中emp为节点名,Employee为emp节点的标签名,(id,name,sal,deptno)为节点属性
2.查(MATCH & RETURN)
MATCH应用:
1. 从数据库获取有关节点和属性的数据
2. 从数据库获取有关节点,关系和属性的数据
RETURN应用:
1. 检索节点的某些属性
2. 检索节点的所有属性
3. 检索节点和关联关系的某些属性
4. 检索节点和关联关系的所有属性
例:查询创建的emp节点
MATCH使用格式
match(emp:Employee)
注意查询时不能仅以查询语句结尾需要有返回值
RETURN使用格式
RETURN
<node-name>.<property1-name>,
........
<node-name>.<propertyn-name>
其中node-name是节点名,property-name是属性名
注意查询时不能单独使用RETURN返回结果,需要有查询语句
查询语句
match(emp:Employee)return emp
3.删(REMOVE & DELETE)
DELETE应用:
1. 删除节点。
2. 删除节点及相关节点和关系。
REMOVE应用:
1. 删除节点或关系的标签
2. 删除节点或关系的属性
这两个命令不应单独使用。
两个命令都应该与MATCH命令一起使用。
例:DELECT删除emp节点
MATCH (e: Employee) DELETE e
例:REMOVE删除emp节点属性
match (emp:Employee)
where emp.id =123
remove emp.id
我们应该使用逗号(,)运算符来分隔标签名称列表。
我们应该使用dot(.)运算符来分隔节点名称和标签名称。