图数据库Neo4j(最详细教程)

这篇具有很好参考价值的文章主要介绍了图数据库Neo4j(最详细教程)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

图数据库Neo4j实战(全网最详细教程)

1. 图数据库Neo4j介绍

1.1 什么是图数据库(graph database)

​ 随着社交、电商、金融、零售、物联网等行业的快速发展,现实社会织起了了一张庞大而复杂的关系网,传统数据库很难处理关系运算。大数据行业需要处理的数据之间的关系随数据量呈几何级数增长,急需一种支持海量复杂数据关系运算的数据库,图数据库应运而生。

​ 世界上很多著名的公司都在使用图数据库,比如:

  • 社交领域:Facebook, Twitter,Linkedin用它来管理社交关系,实现好友推荐

  • 零售领域:eBay,沃尔玛使用它实现商品实时推荐,给买家更好的购物体验

  • 金融领域:摩根大通,花旗和瑞银等银行在用图数据库做风控处理

  • 汽车制造领域:沃尔沃,戴姆勒和丰田等顶级汽车制造商依靠图数据库推动创新制造解决方案

  • 电信领域:Verizon, Orange和AT&T 等电信公司依靠图数据库来管理网络,控制访问并支持客户360

  • 酒店领域:万豪和雅高酒店等顶级酒店公司依使用图数据库来管理复杂且快速变化的库存

    图数据库并非指存储图片的数据库,而是以图数据结构存储和查询数据。

图数据库是基于图论实现的一种NoSQL数据库,其数据存储结构和数据查询方式都是以图论为基础的,图数据库主要用于存储更多的连接数据。

图论〔Graph Theory〕是数学的一个分支。它以图为研究对象图论中的图是由若干给定的点及连接两点的线所构成的图形,这种图形通常用来描述某些事物之间的某种特定关系,用点代表事物,用连接两点的线表示相应两个事物间具有这种关系。

使用 Google+(GooglePlus)应用程序来了解现实世界中 Graph 数据库的需求。 观察下面的图表。

在这里,我们用圆圈表示了Google+应用个人资料

在上图中,轮廓“A”具有圆圈以连接到其他轮廓:家庭圈(B,C,D)和朋友圈(B,C)。

再次,如果我们打开配置文件“B”,我们可以观察以下链接的数据。

​ 像这样,这些应用程序包含大量的结构化,半结构化和非结构化的连接数据。 在 RDBMS 数据库中表示这种非结构化连接数据并不容易。如果我们在 RDBMS 数据库中存储这种更多连接的数据,那么检索或遍历是非常困难和缓慢的。所以要表示或存储这种更连接的数据,我们应该选择一个流行的图数据库。
​ 图数据库非常容易地存储这种更多连接的数据。 它将每个配置文件数据作为节点存储在内部,它与相邻节点连接的节点,它们通过关系相互连接。他们存储这种连接的数据与上面的图表中的相同,这样检索或遍历是非常容易和更快的。

关系查询性能对比:

​ 在数据关系中心,图形数据库在查询速度方面非常高效,即使对于深度和复杂的查询也是如此。在关系型数据库和图数据库(Neo4j)之间进行了实验:在一个社交网络里找到 大深度为5的朋友的朋友,他们的数据集包括100万人,每人约有50个朋友。
实验结果如下:

对比关系型数据库

关系型数据库(RDBMS) 图数据库
节点
列和数据 属性和关系
约束 关系

在关系型数据库中,Person和department之间用外键表示关系:

在图数据库中,节点和关系取代表,外键和join:

在图数据库中,无论何时运行类似JOIN的操作,数据库都会使用此列表并直接访问连接的节点,而无需进行昂贵的搜索和匹配计算。

对比其他NoSQL数据库:

NoSQL数据库大致可以分为四类:

  • 键值(key/value)数据库
  • 列存储数据库
  • 文档型数据库
  • 图数据库

1.2 什么是Neo4j

Neo4j是一个开源的NoSQL图形数据库,2003 年开始开发,使用 scala和java 语言,2007年开始发布。

  • 是世界上 先进的图数据库之一,提供原生的图数据存储,检索和处理;

  • 采用属性图模型(Property graph model),极大的完善和丰富图数据模型;

  • 专属查询语言 Cypher,直观,高效;

官网: https://neo4j.com/

Neo4j的特性:

  • SQL就像简单的查询语言Neo4j CQL
  • 它遵循属性图数据模型
  • 它通过使用Apache Lucence支持索引
  • 它支持UNIQUE约束
  • 它包含一个用于执行CQL命令的UI:Neo4j数据浏览器
  • 它支持完整的ACID(原子性,一致性,隔离性和持久性)规则
  • 它采用原生图形库与本地GPE(图形处理引擎)
  • 它支持查询的数据导出到JSON和XLS格式
  • 它提供了REST API,可以被任何编程语言(如Java,Spring,Scala等)访问
  • 它提供了可以通过任何UI MVC框架(如Node JS)访问的Java脚本
  • 它支持两种Java API:Cypher API和Native Java API来开发Java应用程序

Neo4j的优点:

  • 它很容易表示连接的数据
  • 检索/遍历/导航更多的连接数据是非常容易和快速的
  • 非常容易地表示半结构化数据
  • Neo4j CQL查询语句命令是人性化的可读格式,非常容易学习
  • 使用简单而强大的数据模型
  • 不需要复杂的连接来检索连接的/相关的数据,因为它很容易检索它的相邻节点或关系细节没有连接或索引

1.3 Neo4j数据模型

图论基础

​ 图是一组节点和连接这些节点的关系,图形以属性的形式将数据存储在节点和关系中,属性是用于表示数据的键值对。
​ 在图论中,我们可以表示一个带有圆的节点,节点之间的关系用一个箭头标记表示。
​ 简单的可能图是单个节点:

我们可以使用节点表示社交网络(如Google+(GooglePlus)个人资料),它不包含任何属性。向Google+个人资料添加一些属性:

在两个节点之间建立关系:

此处在两个配置文件之间创建关系名称“跟随”。 这意味着 Profile-I 遵循 Profile-II。

属性图模型

Neo4j图数据库遵循属性图模型来存储和管理其数据。
属性图模型规则

  • 表示节点,关系和属性中的数据
  • 节点和关系都包含属性
  • 关系连接节点
  • 属性是键值对
  • 节点用圆圈表示,关系用方向键表示。
  • 关系具有方向:单向和双向。
  • 每个关系包含“开始节点”或“从节点”和“到节点”或“结束节点”

​ 在属性图数据模型中,关系应该是定向的。如果我们尝试创建没有方向的关系,那么它将抛出一个错误消息。在Neo4j中,关系也应该是有方向性的。如果我们尝试创建没有方向的关系,那么Neo4j会抛出一个错误消息,“关系应该是方向性的”。
​ Neo4j图数据库将其所有数据存储在节点和关系中,我们不需要任何额外的RDBMS数据库或NoSQL数据库来存储Neo4j数据库数据,它以图的形式存储数据。Neo4j使用本机GPE(图形处理引擎)来使用它的本机图存储格式。

图数据库数据模型的主要构建模块是:

  • 节点
  • 关系
  • 属性

简单的属性图的例子:

这里我们使用圆圈表示节点。 使用箭头表示关系,关系是有方向性的。 我们可以用Properties(键值对)来表示Node的数据。 在这个例子中,我们在Node的Circle中表示了每个Node的Id属性。

1.4 Neo4j的构建元素

Neo4j图数据库主要有以下构建元素:

  • 节点
  • 属性
  • 关系
  • 标签
  • 数据浏览器

节点

节点(Node)是图数据库中的一个基本元素,用来表示一个实体记录,就像关系数据库中的一条记录一 样。在Neo4j中节点可以包含多个属性(Property)和多个标签(Label)。

  • 节点是主要的数据元素
  • 节点通过关系连接到其他节点
  • 节点可以具有一个或多个属性(即,存储为键/值对的属性)
  • 节点有一个或多个标签,用于描述其在图表中的作用

属性

属性(Property)是用于描述图节点和关系的键值对。其中Key是一个字符串,值可以通过使用任何 Neo4j数据类型来表示

  • 属性是命名值,其中名称(或键)是字符串
  • 属性可以被索引和约束
  • 可以从多个属性创建复合索引

关系

关系(Relationship)同样是图数据库的基本元素。当数据库中已经存在节点后,需要将节点连接起来 构成图。关系就是用来连接两个节点,关系也称为图论的边(Edge) ,其始端和末端都必须是节点,关系不 能指向空也不能从空发起。关系和节点一样可以包含多个属性,但关系只能有一个类型(Type) 。

  • 关系连接两个节点
  • 关系是方向性的
  • 节点可以有多个甚至递归的关系
  • 关系可以有一个或多个属性(即存储为键/值对的属性)

基于方向性,Neo4j关系被分为两种主要类型:

  • 单向关系
  • 双向关系

标签

标签(Label)将一个公共名称与一组节点或关系相关联, 节点或关系可以包含一个或多个标签。 我们 可以为现有节点或关系创建新标签, 我们可以从现有节点或关系中删除标签。

  • 标签用于将节点分组
  • 一个节点可以具有多个标签
  • 对标签进行索引以加速在图中查找节点
  • 本机标签索引针对速度进行了优化

Neo4j 浏览器

一旦我们安装Neo4j,我们就可以访问Neo4j数据浏览器

访问 http://192.168.65.200:7474/browser

1.5 使用场景

  • 欺诈检测

  • 实时推荐引擎

2. 环境搭建

下载地址:https://neo4j.com/download-center/

安装方式:
1、Neo4j Enterprise Server(企业版)
2、Neo4j Community Server(社区版)
3、Neo4j Desktop(桌面版)

以下为对应的jdk1.8和neo4j的安装包:

链接:https://pan.baidu.com/s/1ZjfP4JJC_QN21j-V_YejrA
提取码:jfqq

安装Neo4j图型数据库步骤:

1.安装jdk1.8

2.安装好jdk后,再安装neo4j

下载好neo4j后,解压完后,配置环境变量:

添加NEO4J_HOME系统变量

添加path变量

%NEO4J_HOME%\bin

配置好所有环境变量后,测试一下:

win+r打开运行,在cmd中输入:

neo4j.bat console

启动后输入Http://localhost:7474 ,访问neo4j,默认账号和密码都为neo4j

2.1安装Neo4j Community Server

注意: neo4j最新版对应的java版本是jdk17

jdk8可以下载Neo4j Community Edition 3.5.28

文档:https://neo4j.com/docs/operations-manual/3.5/

解压到新目录(注意:目录名称不要有中文),比如: D:\neo4j\

# 将Neo4j作为控制台应用程序运行
<NEO4J_HOME>\bin\neo4j console
# 将Neo4j作为服务使用进行安装
<NEO4J_HOME>\bin\neo4j install-service

console: 直接启动 neo4j 服务器

install-service | uninstall-service | update-service : 安装/卸载/更新 neo4j 服务

start/stop/restart/status: 启动/停止/重启/状态

-V 输出更多信息

进入到bin目录,执行

neo4j console

在浏览器中访问http://localhost:7474

使用用户名neo4j和默认密码neo4j进行连接,然后会提示更改密码。

Neo4j Browser是开发人员用来探索Neo4j数据库、执行Cypher查询并以表格或图形形式查看结果的工 具。

3. Neo4j --CQL使用

3.1 Neo4j -- CQL简介

Neo4j的Cypher语言是为处理图形数据而构建的,CQL代表Cypher查询语言。像Oracle数据库具有查询语言SQL,Neo4j具有CQL作为查询语言。

  • 它是Neo4j图形数据库的查询语言。
  • 它是一种声明性模式匹配语言
  • 它遵循SQL语法。
  • 它的语法是非常简单且人性化、可读的格式。

三个共同朋友的社交图:

使用Cypher语言来描述关系:

(fox)<-[:knows]-(周瑜)-[:knows]->(诸葛)-[:knows]->(fox)

3.2 CQL命令使用一

CQL命令官方文档:https://neo4j.com/docs/cypher-manual/3.5/clauses/match/

LOAD CSV

导入csv到neo4j

#将csv文件拷贝到 %NEO4J_HOME%\import目录
load csv from 'file:///西游记,csv' as line
create (:西游{name:line[0],tail:line[1],label:line[3]})

CREATE 创建

create语句是创建模型语句用来创建数据模型

创建节点
#创建简单节点
create (n)
#创建多个节点
create (n),(m)
#创建带标签和属性的节点并返回节点
create (n:person {name:'如来'}) return n
创建关系

Neo4j图数据库遵循属性图模型来存储和管理其数据。

根据属性图模型,关系应该是定向的。 否则,Neo4j将抛出一个错误消息。

基于方向性,Neo4j关系被分为两种主要类型。

  • 单向关系
  • 双向关系
#使用新节点创建关系
CREATE (n:person {name:'杨戬'})-[r:师傅]->(m:person {name:'玉鼎真人'}) return
type(r)
#使用已知节点创建带属性的关系
match (n:person {name:'沙僧'}),(m:person{name:'唐僧'})
create (n)-[r:`师傅`{relation:'师傅'}]->(m) return r
#检索关系节点的详细信息
match (n:person)-[r]-(m:person) return n,m
创建全路径
create p=(:person{name:'蛟魔王'})-[:义兄]->(:person{name:'牛魔王'})<-[:义兄]-
(:person {name:'鹏魔王'}) return p

MATCH 查询

Neo4j CQL MATCH命令用于

  • 从数据库获取有关节点和属性的数据
  • 从数据库获取有关节点,关系和属性的数据
MATCH (n:`西游`) RETURN n LIMIT 25

RETURN返回

Neo4j CQL RETURN子句用于

  • 检索节点的某些属性
  • 检索节点的所有属性
  • 检索节点和关联关系的某些属性
  • 检索节点和关联关系的所有属性
MATCH (n:`西游`) RETURN id(n),n.name,n.tail,n.relation

WHERE子句

像SQL一样,Neo4j CQL在CQL MATCH命令中提供了WHERE子句来过滤MATCH查询的结果。

MATCH (n:person) where n.name='孙悟空' or n.name='猪八戒' RETURN n

#创建关系
match (n:person),(m:person) where n.name='孙悟空' and m.name='猪八戒'
create (n)-[r:师弟]->(m) return n.name,type(r),m.name

DELETE删除

Neo4j使用CQL DELETE子句

  • 删除节点。
  • 删除节点及相关节点和关系。
# 删除节点 (前提:节点不存在关系)
MATCH (n:person{name:"白龙马"}) delete n

# 删除关系
MATCH (n:person{name:"沙僧"})<-[r]-(m) delete r return type(r)

REMOVE删除

有时基于客户端要求,我们需要向现有节点或关系添加或删除属性。我们使用Neo4j CQL REMOVE子句 来删除节点或关系的现有属性。

  • 删除节点或关系的标签
  • 删除节点或关系的属性
#删除属性
MATCH (n:role {name:"fox"}) remove n.age return n

#创建节点
CREATE (m:role:person {name:"fox666"})  #m:role:person  可以给“fox666”既创建role节点又创建person节点
#删除标签
match (m:role:person {name:"fox666"}) remove m:person return m

SET子句

有时,根据我们的客户端要求,我们需要向现有节点或关系添加新属性。要做到这一点,Neo4j CQL提 供了一个SET子句。

  • 向现有节点或关系添加新属性
  • 添加或更新属性值
MATCH (n:role {name:"fox"}) set n.age=32 return n

ORDER BY排序

Neo4j CQL在MATCH命令中提供了“ORDER BY”子句,对MATCH查询返回的结果进行排序。

我们可以按升序或降序对行进行排序。默认情况下,它按升序对行进行排序。 如果我们要按降序对它们 进行排序,我们需要使用DESC子句。

MATCH (n:`西游`) RETURN id(n),n.name order by id(n) desc

UNION子句

与SQL一样,Neo4j CQL有两个子句,将两个不同的结果合并成一组结果

  • UNION

    它将两组结果中的公共行组合并返回到一组结果中。 它不从两个节点返回重复的行。

    限制:

    ​ 结果列类型和来自两组结果的名称必须匹配,这意味着列名称应该相同,列的数据类型应该相同。

  • UNION ALL

    它结合并返回两个结果集的所有行成一个单一的结果集。它还返回由两个节点重复行。

    限制:

    ​ 结果列类型,并从两个结果集的名字必须匹配,这意味着列名称应该是相同的,列的数据类型应该是相同的。

MATCH (n:role) RETURN n.name as name
UNION
MATCH (m:person) RETURN m.name as name

MATCH (n:role) RETURN n.name as name
UNION all
MATCH (m:person) RETURN m.name as name

LIMIT和SKIP子句

Neo4j CQL已提供 LIMIT 子句和SKIP来过滤或限制查询返回的行数。

LIMIT返回前几行,SKIP忽略前几行。

# 前两行
MATCH (n:`西游`) RETURN n LIMIT 2
# 忽略前两行
MATCH (n:person) RETURN n SKIP 2

NULL值

Neo4j CQL将空值视为对节点或关系的属性的缺失值或未定义值。

当我们创建一个具有现有节点标签名称但未指定其属性值的节点时,它将创建一个具有NULL属性值的新 节点。

match (n:`西游`) where n.label is null return id(n),n.name,n.tail,n.label

IN操作符

与SQL一样,Neo4j CQL提供了一个IN运算符,以便为CQL命令提供值的集合。

match (n:`西游`) where n.name in['孙悟空','唐僧'] return id(n),n.name,n.tail,n.label

INDEX索引

Neo4j SQL支持节点或关系属性上的索引,以提高应用程序的性能。

我们可以为具有相同标签名称的所有节点的属性创建索引。

我们可以在MATCH或WHERE或IN运算符上使用这些索引列来改进CQL Command的执行。

Neo4J索引操作

  • Create Index 创建索引
  • Drop Index 丢弃索引
# 创建索引
create index on :`西游` (name)
# 删除索引
drop index on :`西游` (name)

UNIQUE约束

在Neo4j数据库中,CQL CREATE命令始终创建新的节点或关系,这意味着即使您使用相同的值,它也会 插入一个新行。 根据我们对某些节点或关系的应用需求,我们必须避免这种重复。

像SQL一样,Neo4j数据库也支持对NODE或Relationship的属性的UNIQUE约束

UNIQUE约束的优点

  • 避免重复记录。 强
  • 制执行数据完整性规则
#创建唯一约束
create constraint on (n:xiyou) assert n.name is unique
#删除唯一约束
drop constraint on (n:xiyou) assert n.name is unique

DISTINCT

这个函数的用法就像SQL中的distinct关键字,返回的是所有不同值。

match (n:`西游`) return distinct(n.name)

3.3 常用函数

函数 用法
String 字符串 它们用于使用String字面量
Aggregation 聚合 它们用于对CQL查询结果执行一些聚合操作
Relationship 关系 他们用于获取关系的细节,如startnode,endnode等

字符串函数

与SQL一样,Neo4J CQL提供了一组String函数,用于在CQL查询中获取所需的结果。

功能 描述
UPPER 它用于将所有字母更改为大写字母
LOWER 它用于将所有字母改为小写字母
SUBSTRING 它用于获取给定String的子字符串
REPLACE 它用于替换一个字符串的子字符串
MATCH (e) RETURN id(e),e.name,substring(e.name,0,2)

AGGREGATION聚合

和SQL一样,Neo4j CQL提供了一些在RETURN子句中使用的聚合函数。 它类似于SQL中的GROUP BY 子句。

我们可以使用MATCH命令中的RETURN +聚合函数来处理一组节点并返回一些聚合值。

聚集功能 描述
COUNT 它返回由MATCH命令返回的行数
MAX 它从MATCH命令返回的一组行返回最大值
MIN 它返回由MATCH命令返回的一组行的最小值
SUM 它返回由MATCH命令返回的所有行的求和值
AVG 它返回由MATCH命令返回的所有行的平均值
MATCH (e) RETURN count(e)

关系函数

Neo4j CQL提供了一组关系函数,以在获取开始节点,结束节点等细节时知道关系的细节。

功能 描述
STARTNODE 它用于知道关系的开始节点
ENDNODE 它用于知道关系的结束节点
ID 它用于知道关系的ID
TYPE 它用于知道字符串表示中的一个关系的TYPE
match (a)-[r] ->(b) return id(r),type(r)

3.4 neo4j-admin使用(数据库备份、恢复)

数据库备份

对Neo4j数据进行备份、还原、迁移的操作时,要关闭neo4j

cd %NEO4J_HOME%/bin
#关闭neo4j
neo4j stop  #一定要先neo4j install -service,才可以执行neo4j stop
#备份
neo4j-admin dump --database=graph.db --to=/neo4j/backup/graph_backup.dump

数据库恢复

还原、迁移之前 ,要关闭neo4j服务。

#数据导入
neo4j-admin load --from=/neo4j/backup/graph_backup.dump --database=graph.db --
force
#重启服务
neo4j start

4.案例

4.1创建股票知识图谱

创建一个简单的股票知识图谱,包括:

创建节点和关系:

1,建立几只股票的节点

create(n:stock{name:'招商银行',code:'600036',launchDate:date("2002-04-09")}),(:stock{name:'中科创达',code:'300496',launchDate:date("2015-12-10")}),(:stock{name:'华工科技',code:'000988',launchDate:date("2000-06-08")}),(:stock{name:'国信证券',code:'002736',launchDate:date("2014-12-29")})

2,建立上海证券交易所和深圳证券交易所两个节点

create(n:SecuritiesExchange{name:'上海证券交易所'}),(:SecuritiesExchange{name:'深圳证券交易所'}) return n;

3,建立省市地方名称的节点

create(n:Province{name:'湖北'}),(:Province{name:'北京'}),(:Province{name:'广东'}) return n;

4,建立股票和证券交易所关系

#建立'国信证券'和'上海证券交易所'的关系
match(a:stock),(b:SecuritiesExchange) where a.name='国信证券' and b.name='上海证券交易所' create (a)-[r:Exchange]->(b) return r;
#建立'招商银行'和'上海证券交易所'的关系
match(a:stock),(b:SecuritiesExchange) where a.name='招商银行' and b.name='上海证券交易所' create (a)-[r:Exchange]->(b) return r;
#建立'华工科技'和'深圳证券交易所'的关系
match(a:stock),(b:SecuritiesExchange) where a.name='华工科技' and b.name='深圳证券交易所' create (a)-[r:Exchange]->(b) 
#建立'华工科技'和'深圳证券交易所'的关系
match(a:stock),(b:SecuritiesExchange) where a.name='华工科技' and b.name='深圳证券交易所' create (a)-[r:Exchange]->(b) 

5,建立股票和省市名称关系

#建立'华工科技'和'北京'的关系
match(a:stock),(b:Province) where a.name='华工科技' and b.name='北京' create (a)-[r:Area]->(b)
#建立'中科创达'和'北京'的关系
match(a:stock),(b:Province) where a.name='中科创达' and b.name='北京' create (a)-[r:Area]->(b)
#建立'招商银行'和'湖北'的关系
match(a:stock),(b:Province) where a.name='招商银行' and b.name='湖北' create (a)-[r:Area]->(b)
#建立'国信证券'和'广东'的关系
match(a:stock),(b:Province) where a.name='国信证券' and b.name='广东' create (a)-[r:Area]->(b)
#建立'中科创达'和'国信证券'的关系
 create (n:stock{name:'中科创达'})-[r:同行]->(:stock{name:'国信证券'}) return r
#建立'华工科技'和'中科创达'为同行的关系
match(a:stock{name:'华工科技'}),(b:stock{name:'中科创达'}) create (a)-[r:`同行`{relation:'同行'}]->(b) return type(r)
#建立'华工科技'和'招商银行'为同行的关系
match(a:stock{name:'华工科技'}),(b:stock{name:'招商银行'}) create (a)-[r:同行]->(b) return type(r)

查询节点和关系:

6,查询某个股票的节点

#查询'招商银行'股票节点
match (a:stock) where a.name='招商银行' return a;

7,查询某个标签的所有节点

#查询‘stock’标签的所有节点
match(a:stock) return a;

8.查询两个节点之间的关系

#查询‘华工科技’和‘北京’之间的关系
match(:stock{name:'华工科技'})-[r]->(:Province{name:'北京'}) return type(r)

返回结果:type(r)  "Area"

9,通过函数type获取关系的类型

match(:stock{name:'华工科技'})-[r]->() return type(r);
返回结果:type(r)  "Area" "Exchange"

删除节点和关系
10,删除股票的节点

#如果该节点存在关系,先删关系,再删节点。
match(a:stock) where a.name='中科创达' delete a

11,删除某个标签的节点

#删除‘stock’标签的节点
match(n:stock) delete n
#删除所有标签节点
match(n) delete n

12,删除两个节点的关系

#删除'中科创达'和'国信证券'之间的关系
match(:stock{name:'中科创达'})-[r]->(:stock{name:'国信证券'}) delete r

#删除'中科创达'节点之间的关系
match(:stock{name:'中科创达'})-[r]->() delete r

13,删除全部关系

#删除'stock'标签的全部关系
match(:stock)-[r]->() delete r

更新图形
set子句,用于对更新节点的标签和实体的属性;remove子句,用于删除实体的属性和节点的标签;
14,增加节点属性

#增加'湖北'节点的属性
match(a:Province) where a.name='湖北' set a.abbreviation='HN' return a
match(a:Province) where a.name='湖北' set a.person='2000' return a

15,删除节点属性文章来源地址https://www.toymoban.com/news/detail-819375.html

#删除‘湖北’节点属性
match(a:Province) where a.name='湖北' remove a.person 

4.2 利用CQL构建明星关系图谱

#导入明星数据
load csv from 'file:///明星1.csv' as line
create (:star {num:line[0],name:line[1]})
load csv from 'file:///明星关系数据1.csv' as line
create (:starRelation
{from:line[0],subject:line[1],to:line[2],object:line[3],relation:line[4]})
#查询明星关系
match (n:star),(m:starRelation),(s:star) where n.name='刘烨' and m.subject='刘烨'
and s.name=m.object
return n.name,m.relation,s.name
# 创建关系 构建明星关系图谱
match (n:star),(m:starRelation),(s:star) where n.name='刘烨' and m.subject='刘烨'
and s.name=m.object
create (n)-[r:关系{relation:m.relation}]->(s)
return n.name,m.relation,s.name
#查看明星关系
MATCH p=(n:star{name:'刘烨'})-[r:`关系`]->() RETURN p


# 构建明星全部关系图谱
match (n:star1),(m:starRelation),(s:star1) where n.name=m.subject and s.name=m.object
create (n)-[r:明星关系{relation:m.relation}]->(s)
# return n.name,m.relation,s.name  (可以不写也)

到了这里,关于图数据库Neo4j(最详细教程)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 图形数据库的实战应用:如何在 Neo4j 中有效管理复杂关系

    关系数据库管理系统( RDBMS ) 代表了最先进的技术,这在一定程度上要归功于其由周边技术、工具和广泛的专业技能组成的完善的生态系统。 在这个涵盖信息技术(IT) 和运营技术(OT) 的技术革命时代,人们普遍认识到性能方面出现了重大挑战,特别是在NoSQL 解决方案优于传统方

    2024年02月03日
    浏览(46)
  • Neo4j:入门基础(二)~ 数据导入Neo4J RDF导入neo4j数据库

    neo4j导入数据的方式有以下几种: Cypher create 语句,为每一条数据写一个create Cypher load csv 语句,将数据转成CSV格式,通过LOAD CSV读取数据。 neo4j-admin import导入 官方提供的Java API - BatchInserter 大牛编写的 batch-import 工具 neo4j-apoc load.csv + apoc.load.relationship 针对实际业务场景,定制

    2023年04月24日
    浏览(42)
  • Neo4j | 保姆级教学之如何清空neo4j数据库

    要清空neo4j数据库,需要进行以下操作: 停止Neo4j服务器,关闭Neo4j的所有连接。 找到 Neo4j 数据库存储的目录,通常是 data/databases/ 。 删除该目录中的所有文件和子目录。 请注意,这将不可逆地删除数据库的所有内容,包括节点、关系和属性等数据。在执行这个操作之前,请

    2024年02月06日
    浏览(35)
  • Neo4j数据库删除数据

    我们使用Neo4j图数据库进行写入数据操作之后,免不了要删除数据的。 但是Neo4j的控制台没有提供快捷的删除按钮,所以我们还是需要通过命令来操作。 如果数据库中的数据量并不大,节点数相对较少,我们可以通过命令行直接删除节点。 此类操作起到清空数据库的效果,但

    2023年04月09日
    浏览(79)
  • Neo4j 图形数据库

    目录 Neo4j 基础 什么是Neo4j Neo4j 模块构建 Neo4j的主要应用场景 Neo4j 环境搭建 Docker 安装Neo4j Neo4j数据浏览器  Neo4j CQL CQL简介 Neo4j CQL高级 CQL 函数 CQL多深度关系节点 事务 索引 约束 Neo4j之Admin管理员操作 Neo4j - 数据库备份和恢复 调优思路  Neo4j 程序访问 SpringBoot 整合Neo4j

    2024年02月10日
    浏览(35)
  • neo4j清空数据库

    清空所有Person、 Movie节点及其所有关系 查询任意数据  如果没有, 就说明已经删除成功了 这段代码是用Cypher查询语言编写的,用于清空所有的Person节点、Movie节点以及它们之间的所有关系。让我们逐步解释代码的每个部分: 这部分代码使用MATCH语句来查找图数据库中的所有

    2024年02月14日
    浏览(31)
  • 图数据库_Neo4j的使用场景_以及Windows版Neo4j Community Server安装_欺诈检测_推荐_知识图谱---Neo4j图数据库工作笔记0003

    可以看到使用场景,比如欺诈检测, 要建立图谱,才能进行,欺诈人员检测   可以看到图谱的各种应用场景 然后推荐引擎也需要,可以看到 在金融,旅行,求职招聘,保健,服务,媒体娱乐,都可以进行推荐   然后还有知识图谱 身份访问管理,这里,可以进行安全管理,可以挖掘出潜在关系

    2024年02月12日
    浏览(31)
  • Neo4j数据库使用相关

    做知识图谱相关项目,初步使用了neo4j数据库,简单记录一下使用过程和踩坑备忘~ 操作系统Win10+Neo4j社区版(community,版本4.4.30) 目录 一、安装 1.1 安装Java和Neo4j 1.2 环境变量设置 二、 Neo4j使用 2.1 安装服务 2.2 数据库使用 2.3 数据库备份  Java下载链接:Java Downloads | Oracle

    2024年04月16日
    浏览(46)
  • 图数据库Neo4j简介

    随着社交、电商金融、零售、物联网的快速发展,现实社会支起了一张张庞大二复杂的关系网,传统数据库很难处理关系运算,急需一种支持海量复杂数据关系运算的数据库,图数据库应运而生。 图数据库是基于图论实现的一种Nosql数据库,起数据结构和数据查询方式都是以

    2024年02月22日
    浏览(40)
  • 图数据库Neo4j——SpringBoot使用Neo4j & 简单增删改查 & 复杂查询初步

    图形数据库是专门用于存储图形数据的数据库,它使用图形模型来存储数据,并且支持复杂的图形查询。常见的图形数据库有Neo4j、OrientDB等。 Neo4j是用Java实现的开源NoSQL图数据库,本篇博客介绍如何在SpringBoot中使用Neo4j图数据库,如何进行简单的增删改查,以及如何进行复杂

    2024年02月06日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包