neo4j入门并使用案例说明

1、neo4j是什么

Neo4j是一个高性能的NoSQL图形数据库,它将结构化数据存储在网络(在数学角度称为图)上,而不是传统的表中。Neo4j是一个嵌入式的、基于磁盘的、具备完全的事务特性的Java持久化引擎。它因其高性能、轻量级、易嵌入和完全支持事务等特性而受到关注。

Neo4j使用Cypher查询语言,这是一种易于理解和使用的查询语言,支持ACID事务,保证了数据的一致性和可靠性。Neo4j支持高效的图数据查询和存储,能够快速处理复杂的关系数据,并且具有强大的可扩展性,可以处理数十亿节点/关系/属性的图,并扩展到多台机器并行运行。

2、neo4j可以用来做什么

Neo4j的应用场景非常广泛,包括社交网络分析、知识图谱、推荐系统、面向对象数据库、欺诈检测等。例如,在社交网络分析中,Neo4j可以存储和查询用户和关系,用于推荐系统、好友推荐等应用。在知识图谱领域,Neo4j可以存储和查询概念、关系和属性,用于智能问答系统、信息检索等应用。

3、为什么选择neo4j

先说说我的需求场景。系统的库、表特别多,为了统一管理,实现了元数据管理模块。但是接踵而来的需求是业务希望能够直观的看到库、表、字段分别是从哪里来的,作用在哪里。其实就是想要一份数据血缘。从而更好的了解数据、管理数据。

为什么不存在关系型数据库中。因为关系型数据库更关注数据的ALTP。对于关系的存储不是不可以,而是不适合。

  1. 原生图形数据库:Neo4j是一个原生图形数据库,这意味着它是为图形数据结构和查询而设计的。图形数据模型能够自然地表示实体及其之间的关系,非常适合用于社交网络、推荐系统、供应链管理等需要处理复杂关系的领域。

  2. 高效的查询性能:Neo4j使用图遍历算法进行查询,这使得它在处理复杂关系查询时非常高效。相比传统的关系型数据库,Neo4j在查询涉及多个实体和关系时能够提供更快的响应速度。

  3. 灵活的数据模型:Neo4j的数据模型非常灵活,可以方便地表示各种复杂的关系和属性。它支持节点和边的添加、删除和修改,使得数据的存储和更新变得简单直观。

  4. 可扩展性:Neo4j具有良好的可扩展性,可以处理大规模图形数据。它支持集群部署和分片,能够将数据分布到多个节点上,提高系统的吞吐量和可靠性。

  5. 强大的社区支持:Neo4j拥有一个活跃的社区,提供了大量的学习资源和工具,帮助用户更好地使用Neo4j。此外,Neo4j还提供了丰富的API和驱动,方便与其他系统和应用集成。

  6. 易于使用:Neo4j提供了直观的图形界面(Neo4j Browser)和友好的查询语言(Cypher),使得用户可以轻松地查看、查询和操作图形数据。

其中最看重的是使用是否方便,社区支持是否够强大。其实说白了就是团队其他成员(特别是小白,不了解的同学)能否快速上手解决实际问题。如果出现问题网上是否能快速的找到解决方案(你遇到的百分之八十都是别人遇到过的)。所以基于上述选择了neo4j作为数据血缘的实现方案。

4、neo4j的使用

安装

主要分为社区版和企业版。我们使用社区版就完全够用,因为他所支持的数据量级就公司目前很长一段时间而言是完全够用的。所以也没必要上企业版(留下了没钱的眼泪)。

安装使用linux和mac很方便,windows本人没有尝试过,可以在网上找找方案。

linux和mac的安装网上也有很多的文章,此处就不再详述。

我是使用docker进行安装的,就两步,pull、run。当然前提是已经安装了docker

使用

neo4j作为数据库,可以参考关系型数据库的使用方式。建表、设置关系、查询。如果想深入了解下更多的语法,可以百度搜到很多Cypher语法。不是本文的重点。

案例

前面说了很多,都是一些概念,其实大家更多的是想快速的上手使用。所以这里用一个简单的案例说明一下如何使用neo4j实现关系构建和查询。

有三个节点。学校、教师、学生。不同的教师可以就职不同的学校。教师可以给学生们进行指定学科的授课。学生可以参加其他学校老师组织的线下补习班。

最终想要查询到某一个教师就职与那个学校;某一个教师所教授了那些学生;某一个教师是否有开设补习班,他的补习班有那些学生。如果想的话,还可以构建学生与学校的关系。查询出来这些学生属于那些学校的。怎么样,如果使用关系型数据库搞这个关系,是不是头都大了!话不多说,让我们开始吧。

构建学校节点:

create(school:School{id:1,name:'第一中学'});
create(school:School{id:2,name:'第二中学'})

构建教师节点:

create(teacher:Teacher{id:1,name:'杨老师',subject:'数学'});
create(teacher:Teacher{id:2,name:'高老师',subject:'语文'});

create(teacher:Teacher{id:3,name:'刘老师',subject:'数学'});
create(teacher:Teacher{id:4,name:'金老师',subject:'语文'})

构建学生节点:

create(student:Student{id:1,name:'张三'});
create(student:Student{id:2,name:'李四'});
create(student:Student{id:3,name:'王五'});

create(student:Student{id:4,name:'赵六'});
create(student:Student{id:5,name:'侯七'});
create(student:Student{id:6,name:'周八'})

构建学校-教师关系

match(teacher:Teacher),(school:School) where teacher.id = 1 and school.id = 1 create(teacher)-[:work]->(school);
match(teacher:Teacher),(school:School) where teacher.id = 2 and school.id = 1 create(teacher)-[:work]->(school);
match(teacher:Teacher),(school:School) where teacher.id = 3 and school.id = 2 create(teacher)-[:work]->(school);
match(teacher:Teacher),(school:School) where teacher.id = 4 and school.id = 2 create(teacher)-[:work]->(school);

构建教师-学生关系

match(teacher:Teacher),(student:Student) where (student.id = 1 or student.id = 2) and teacher.id = 1 create(teacher)-[:教授数学]->(student);
match(teacher:Teacher),(student:Student) where student.id = 3 and teacher.id = 2 create(teacher)-[:教授语文]->(student);

match(teacher:Teacher),(student:Student) where student.id = 4 and teacher.id = 3 create(teacher)-[:教授数学]->(student);
match(teacher:Teacher),(student:Student) where (student.id = 5 or student.id = 6) and teacher.id = 4 create(teacher)-[:教授语文]->(student)

构建学生课外补习教师关系

match(teacher:Teacher),(student:Student) where student.id = 1 and teacher.id = 3 create(student)-[:数学课外补习]->(teacher)

使用查询语句查询关系图

match(school:School),(teacher:Teacher),(student:Student) return school,teacher,student

指定教师,学校、学生的关系,查询某一个教师的关系图谱

match (school:School),(teacher:Teacher),(student:Student) where teacher.id =3 and (teacher)-[:work]->(school) and ((student)-[:`数学课外补习`]->(teacher) or (teacher)-[:`教授数学`]->(student))  return school,teacher,student

结合这个简单的案例,将自己的关系数据进行设计。然后写入neo4j。组成关系图谱。后续使用这个数据进行关系查询。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/683058.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

c++(内存分配,构造,析构)

#include <iostream>using namespace std; class Per { private:string name;int age;double *height;double *weigh; public://无参构造Per(){cout << "Per::无参构造" << endl;}//有参构造Per(string name,int age,double height,double weigh):…

私募状告基金经理,七千月薪被索赔上百万

一个私募机构的基金经理&#xff0c;月薪七千元&#xff0c;但是却被公司诉讼追索100多万元赔偿。 这样“奇葩”的事情&#xff0c;不仅发生在视频网剧里&#xff0c;也发生在现实生活中。 根据日前相披露的一则案件文书&#xff0c;一家江浙一带的私募机构日前把自己的“基金…

docker create rm export exec命令详解

容器生命周期管理命令教程-3 1. 创建容器 docker create&#xff1a;创建一个新的容器但不启动它。 docker create -it --name mycontainer ubuntu bash通常使用 docker run(详细可看上一篇关于run命令的详细介绍) 2. 删除容器 docker rm&#xff1a;删除一个或多个容器。 d…

计算机网络9——无线网络和移动网络1 无线局域网 WLAN2

文章目录 一、802.11局域网的 MAC 层协议1、CSMA/CA协议2、时间间隔 DIFS 的重要性3、争用信道的过程4、对信道进行预约 二、802.11局域网的 MAC 帧1&#xff09;关于 802.11 数据帧的地址2&#xff09;序号控制字段、持续期字段和帧控制字段 一、802.11局域网的 MAC 层协议 1…

Spring boot+vue前后端分离

目录 1、前端vue的搭建 2、后端项目的构建 pom文件中引入的jar包 yml文件用来配置连接数据库和端口的设置 application.property进行一些整合 service层 imp层 mapper 实体类 额外写一个类、解决跨域问题 3、测试 1、前端vue的搭建 建立项目的过程略 开启一个建立好…

探索营销系统业务架构的设计与应用

随着市场竞争的日益激烈和消费者需求的不断变化&#xff0c;营销系统作为企业营销管理的重要组成部分&#xff0c;扮演着至关重要的角色。本文将深入探讨营销系统业务架构的设计与应用&#xff0c;从客户关系管理、营销活动管理、数据分析和智能化服务等方面进行全面解析&#…

Leetcode3168. 候诊室中的最少椅子数

Every day a Leetcode 题目来源&#xff1a;3168. 候诊室中的最少椅子数 解法1&#xff1a;模拟 代码&#xff1a; /** lc appleetcode.cn id3168 langcpp** [3168] 候诊室中的最少椅子数*/// lc codestart class Solution { public:int minimumChairs(string s){int chair…

学习笔记——路由网络基础——浮动静态路由(路由备份和冗余)

2、浮动静态路由(路由备份和冗余) (1)基本概念 浮动静态路由是两条或多条链路组成浮动路由。当到达某一网络有多条路径&#xff0c;通过为静态路由设置不同的优先级&#xff0c;你可以指定主用路径和备用路径。当主用路径不可用时&#xff0c;走备用路径的静态路由进入路由表…

LeakSearch:针对网络公开凭证的安全扫描与检测工具

关于LeakSearch 在红队演戏过程中&#xff0c;往往需要获取到针对目标域的访问权限。在这个过程中&#xff0c;很多红队人员会选择使用暴露在互联网上的代理服务器来实现目标域的访问&#xff0c;那么此时就需要在互联网上收集公开暴露的凭证信息。 对于蓝队来说&#xff0c;…

使用HTML、CSS和Javascript编写一个注册界面(二)

倘若代码中有任何问题或疑惑&#xff0c;欢迎提出交流哦~ 在上一篇文章我们实现了页面的建设&#xff0c;接下来我们实现JavaScript交互逻辑。 交互功能&#xff1a; 密码显示当用户输入的内容不符合规范时报错在提交注册界面是若有报错则提交失败 密码显示 要实现密码显示的…

【kubernetes】k8s集群中的ingress(对外服务)规则详解

目录 一、Ingress 简介 1.1service的作用 1.2外部访问方案 (四种&#xff09;&#x1f339;&#x1f339;&#x1f339; 部署externalIPs 1.3Ingress 是什么 二、Ingress 组成&#x1f339;&#x1f339;&#x1f339; 三、Ingress 工作原理&#x1f431;&#x1f…

TSR,FSR,DLSS超级分辨率的原理分析

先了解一些时域抗锯齿的方法&#xff1a; TAA&#xff1a; 抖动 TAA 的主要原理是跨帧计算多个子像素样本&#xff0c;然后将它们组合成一个最终像素。最简单的方案是在像素内生成随机样本&#xff0c;但有更好的方法来生成固定序列的样本。选择一个好的序列以避免聚集非常重…

LeetCode-数学基础开篇

概念 1.实数 2.指数函数 f(x) &#xff08;a&#xff1e;0且a≠1&#xff09;【a: 底数&#xff08;常量&#xff09;&#xff0c;x: 指数&#xff08;变量&#xff09;】 特征&#xff1a;指数函数在x轴没有交点&#xff0c;是光滑的曲线 3.幂函数 f(x) 【x&#xff…

Nginx的https功能

一.HTTPS功能简介 Web网站的登录页面都是使用https加密传输的&#xff0c;加密数据以保障数据的安全&#xff0c;HTTPS能够加密信息&#xff0c;以免敏感信息被第三方获取&#xff0c;所以很多银行网站或电子邮箱等等安全级别较高的服务都会采用HTTPS协议&#xff0c;HTTPS其实…

Python——range() 函数用法详解

Python——range() 用法详解 range() 是一个用于生成整数序列的内置函数&#xff0c;在Python中常用于循环迭代等场景。 它可以接受一个或多个参数&#xff0c;生成一个按指定规则的整数序列。 1.range() 函数的语法 range(stop) range(start, stop,[step])start&#xff1…

1. lvs负载均衡

lvs负载均衡 一、集群技术概述1、集群技术类型2、负载均衡技术3、高可用技术 二、负载均衡 LVS1、LVS介绍2、负载均衡策略/算法3、LVS设计模式3.1 NAT模式的注意事项3.2 DR 直接路由模式的注意事项 三、LVS nat模式的实现1、确认后端服务器网关正确2、安装ipvsadm软件3、开启路…

Java 实验8 集合类

&#xff08;一&#xff09;实验目的 1、掌握JAVA集合类中的Collection的特点及其应用情形&#xff1b; 3、掌握Collection、熟悉集合的特点及应用。 &#xff08;二&#xff09;实验内容和步骤 1、仿照课堂练习的MyStack示例&#xff0c;使用LinkedList集合类实现一个先进…

Java项目:100 springboot共享汽车管理系统

作者主页&#xff1a;舒克日记 简介&#xff1a;Java领域优质创作者、Java项目、学习资料、技术互助 文中获取源码 项目介绍 本共享汽车管理系统有管理员和用户。 管理员功能有个人中心&#xff0c;用户管理&#xff0c;投放地区管理&#xff0c;汽车信息管理&#xff0c;汽车…

xrun简单的仿真环境

xrun xceliun makefile文本 all: clean comp ela sim comp:xrun -64bit -compile test.v accessrwc ela:xrun -64bit -elaborate test.v accessrwc sim:xrun -64bit -R -gui clean:xrun -clean 仿真代码 timescale 1ns/1ns module test (); reg clk; initial beginclk 1b…

xtsk—选择自由

最近和一些自由职业者交流时深刻感受到&#xff0c;系统思考不是为了创造更多的工作&#xff0c;而是为了创造更多的自由。我们工作的最终目的&#xff0c;实际上是为了达到不需要为了生存而工作的自由状态&#xff0c;赚钱只是手段&#xff0c;其本质是为了赢得更多的选择权。…