- 性能上,对长程关系的查询速度快
- 擅于发现隐藏的关系,例如通过判断图上两点之间有没有走的通的路径,就可以发现事物间的关联
3、Neo4j基础
3.1 什么是Neo4j
Neo4j是一个开源的 无Shcema的 基于java开发的 图形数据库,它将结构化数据存储在图中而不
是表中。它是一个嵌入式的、基于磁盘的、具备完全的事务特性的Java持久化引擎。程序数据是
在一个面向对象的、灵活的网络结构下,而不是严格、静态的表中,但可以享受到具备完全的事务
特性、企业级的数据库的所有好处。
https://db-engines.com/en/ranking
3.2 Neo4j模块构建
Neo4j 主要构建块
节点
节点是图表的基本单位。 它包含具有键值对的属性
属性
属性是用于描述图节点和关系的键值对
Key =
值
其中
Key
是一个字符串
值可以通过使用任何
Neo4j
数据类型来表示
关系
关系是图形数据库的另一个主要构建块。 它连接两个节点,如下所示。
这里
Emp
和
Dept
是两个不同的节点。
“WORKS_FOR”
是
Emp
和
Dept
节点之间的关系。
因为它表示从
Emp
到
Dept
的箭头标记,那么这种关系描述的一样
Emp WORKS_FOR Dept
每个关系包含一个起始节点和一个结束节点。
这里
“Emp”
是一个起始节点。
“Dept”
是端节点。
由于该关系箭头标记表示从
“Emp”
节点到
“Dept”
节点的关系,该关系被称为
“
进入关系
”
到
“Dept”
节点。
并且
“
外向关系
”
到
“Emp”
节点。
像节点一样,关系也可以包含属性作为键值对。
标签
Label
将一个公共名称与一组节点或关系相关联。 节点或关系可以包含一个或多个标签。 我们可以为现
有节点或关系创建新标签。 我们可以从现有节点或关系中删除现有标签。
从前面的图中,我们可以观察到有两个节点。
左侧节点都有一个标签:
“EMP”
,而右侧节点都有一个标签:
“Dept”
。
这两个节点之间的关系,也有一个标签:
“WORKS_FOR”
注:
-
Neo4j
将数据存储在节点或关系的属性中。
3.3 Neo4j的主要应用场景
社交媒体和社交网络
当使用图形数据库为社交网络应用程序提供动力时,可以轻松利用社交关系或根据活动推断关系。
查询社区聚类分析,朋友的朋友推荐,影响者分析,共享和协作关系分析等
推荐引擎和产品推荐系统
图形驱动的推荐引擎通过实时利用多种连接,帮助公司个性化产品,内容和服务。
内容和媒体推荐,图形辅助搜索引擎,产品推荐,专业网络,社会推荐。
身份和访问管理
使用图形数据库进行身份和访问管理时,可以快速有效地跟踪用户,资产,关系和授权。
查询访问管理,资产来源,数据所有权,身份管理,互连组织,主数据,资源授权
金融反欺诈多维关联分析场景
通过图分析可以清楚地知道洗钱网络及相关嫌疑,例如对用户所使用的帐号、发生交易时的
IP
地址、
MAC
地址、手机
IMEI
号等进行关联分析。
3.4 Neo4j环境搭建
Neo4j环境Linux下搭建
(1).
切换到
Linux
下 到安装目录
neo4j
上传安装包 或者 下载安装包,这里需要注意,Neo4j的4.0版本以上需要jdk11的支持
使用
ftp
工具上传
neo4j-community-3.5.17.tar
到
liunx
下
或者
wget
https://neo4j.com/artifact.php?name=neo4j-community-3.5.17-unix.tar.gz
(2).
解压
tar -xvf neo4j-community-3.5.17.tar
(3).
修改配置文件
neo4j.conf
vi conf/neo4j.conf
主要是修改
允许远程访问的地址
把对应的注释打开即可
dbms.connectors.default_listen_address=0.0.0.0
(4).
开放对应的访问端口
默认要开放
7474
和
7687
fifirewall-cmd --zone=public --add-port=7474/tcp --permanent
fifirewall-cmd --zone=public --add-port=7687/tcp --permanent
systemctl reload fifirewalld
(5).
启动
./bin/neo4j start
(6).
使用浏览器 访问服务器上的
neo4j
http://127.0.0.1:7474
默认的账号是
neo4j
密码
neo4j
这里第一次登录的话会要求修改密码
Windows
下的安装
(1).
从
https://neo4j.com/download-center/#community
下载最新的
Neo4j Server
安装文件
可以看到
neo4J
软件
exe
或
zip 格式的所有版本,这里需要注意,Neo4j的4.0版本以上需要jdk11的支持
(2).
下载
Neo4j 3.5.17 (zip)
(3).
解压
(4).
修改配置文件
dbms.connectors.default_listen_address=0.0.0.0
(5) .
通过
neo4j.bat install-service
安装
neo4j
服务
修改文件
bin/neo4j.ps1
Import-Module "neo4j
的主目录
\bin\Neo4j-Management.psd1"
(6).neo4j.bat
启动
neo4j.bat start
(7).
使用浏览器 访问服务器上的
neo4j
http://127.0.0.1:7474
默认的账号是
neo4j
密码
neo4j
这里第一次登录的话会要求修改密码
3.5 Neo4j数据浏览器
数据浏览器访问
一旦我们安装
Neo4j
,我们可以访问
Neo4j
数据浏览器使用以下
URL
http:// localhost:7474/browser/
Neo4j
数据浏览器用于执行
CQL
命令并查看输出输出。
这里我们需要在美元提示符处执行所有
CQL
命令:
“$”
如
CREATE(cc:CreditCard)
在美元符号后键入命令,然后单击
“
执行
”
按钮运行命令。
它与
Neo4j
数据库服务器交互,检索和显示下面的结果到那个美元提示。
使用
“VI
视图
”
按钮以图形格式查看结果。 上图以
“UI
视图
”
格式显示结果。
导出
CSV
或者
JSON
单击
“
导出
CSV”
按钮以
csv
文件格式导出结果
------------------------------------------------------------------------------------------------------------------------------
在公司里面基础业务逻辑curd+简单缓存写多了,对个人发展真的非常不利,自己通过碎片时间学习总是不系统,各种版本问题也让人经常受挫,记忆上记得最新的忘了前面的,面试时总错过机会,偶然在拉勾上看到有java高薪训练营,对标阿里P7,看课程设计中广度和深度都有,就报上了,现在学习了40%+,手写mybatis+源码讲解、springboot源码、分布式理论及集群场景化、Dubbo、SpringCloud。。。,受益良多,自信了很多,相信学完后能力有较大提升,可以找到心仪的工作。