图数据库 Neo4j简介及增删查操作

图数据库 Neo4j

现实中很多数据都是用图来表达的,比如社交网络中人与人的关系、地图数据、或是基因信息等等。

RDBMS 并不适合表达这类数据,而且由于海量数据的存在,让其显得捉襟见肘。

图数据库简介

NoSQL 数据库的兴起,很好地解决了海量数据的存放问题,图数据库也是 NoSQL 的一个分支,相比于 NoSQL 中的其他分支,它很适合用来原生表达图结构的数据。

Neo4j 是图数据库中一个主要代表,其开源,且用 Java 实现。

其有两种运行方式

  1. 一种是服务的方式,对外提供REST接口;
  2. 另外一种是嵌入式模式,数据以文件的形式存放在本地,可以直接对本地文件进行操作。

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(.)运算符来分隔节点名称和标签名称。

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值