neo4j springboot 日志_springBoot 与neo4j的简单整合

Neo4j简介

Neo4j是基于java语言实现的世界领先的图形数据库, 是一个高性能的图形存储,具有成熟和强大的数据库所需的所有功能,如友好的查询语言(Cypher)和ACID事务。对于许多应用程序,与关系数据库相比,Neo4j提供了数量级的性能优势。主要应用于图检索和关系计算。其优点在于:

节点没上线(3.0以后去掉了限制)

扩展性很好,支持集群和企业版

数据ETL有丰富的工具支持,自带GUI

良好的WebUI

Neo4j安装

Neo4j在不同部署环境中的安装,例如Linux,Mac OS,Windows,Debian,Docker或CAPI Flash,以下介绍在windows系统中的安装方法:

1.下载最新安装包

点击以下地址:https://neo4j.com/download-ce...,选择社区服务器下相应版本下载即可。

2.安装Neo4j

解压安装包到相应目录后在bin目录下打开命令提示符或者任意地方打开命令提示符进入bin目录下

如图的四个命令:

(1)进入bin目录下

(2)neo4j 查询相应命令

(3)install-service 安装Neo4j服务

(4)start 启动服务

服务安装成功之后浏览器输入 http://localhost:7474/browser/ 即可访问登录页面,其中用户名密码都为neo4j,登陆后可修改密码,登录页面如下图

其余环境的服务安装方法可参考:https://neo4j.com/docs/operat...

Neo4j与springBoot简单整合

大概了解了Neo4j和进行安装之后,接下来就对Neo4j和springBoot进行一个简单的整合,如图实例我们依据图中人物与电影的关系建立一个简单的demo(图片源自官方文档)

建立一个springBoot项目

2.引入neo4j的pom

org.springframework.boot

spring-boot-starter-data-neo4j

3.建立一个Person和Movie的实体类

@NodeEntity

public class Person {

@Id

@GeneratedValue

private Long id;

private String name;

private String born;

public Person() {// 从 Neo4j API 2.0.5开始需要无参构造函数

}

public Person(String name, String born) {

this.name = name;

this.born = born;

}

//省略getter and setter

@NodeEntity

public class Movie {

@Id

@GeneratedValue

private Long id;

private String title;

private String released;

public Movie() {

}

public Movie(String title, String released) {

this.title = title;

this.released = released;

}

//省略getter and setter

需要注意的是类上@NodeEntity,标识这是一个节点,实体类中还需要一个无参构造方法,从 Neo4j API 2.0.5开始需要的。

4.建立MovieRepository和PersonRepository

public interface MovieRepository extends CrudRepository {

Movie findByTitle(String title);

}

public interface PersonRepository extends CrudRepository {

Person findByName(String name);

}

其中继承CrudRepository已经可以实现简单的CRUD了

5.在Person中建立movie与演员、导演的指向关系

@Relationship(type = "ACTED_IN", direction = Relationship.OUTGOING)

public Set actors;

public void addActor(Movie movie) {

if (actors == null) {

actors = new HashSet<>();

}

actors.add(movie);

}

@Relationship(type = "DIRECTED", direction = Relationship.OUTGOING)

public Set directors;

public void addDirector(Movie movie) {

if (directors == null) {

directors = new HashSet<>();

}

directors.add(movie);

}

@Relationship这个注解表示关系,type是关系名称,direction是方向,例子中的是person——>movie

6.application.properties配置文件中建立数据库连接

#本地连接可以省略该行,非本地配置改对应ip

#spring.data.neo4j.uri=bolt://localhost

spring.data.neo4j.username=neo4j

spring.data.neo4j.password=123456

7.单元测试

(1)创建movie

@Test

public void testSaveMovie() {

Movie m1 = new Movie("无问西东", "2018");

Movie m2 = new Movie("罗曼蒂克消亡史", "2016");

movieRepo.save(m1);

movieRepo.save(m2);

}

可以看到数据库已经建立两部电影的相关节点

(2)创建person及其与movie的关系

@Test

public void testSavePerson() {

Person p1 = new Person("章子怡", "1979");

Person p2 = new Person("李芳芳", "1976");

Person p3 = new Person("程耳", "1970");

Movie m1 = movieRepo.findByTitle("罗曼蒂克消亡史");

Movie m2 = movieRepo.findByTitle("无问西东");

if (m1!=null) {

p1.addActor(m1);

p3.addDirector(m1);

}

if (m2!=null) {

p1.addActor(m2);

p2.addDirector(m2);

}

personRepo.save(p1);

personRepo.save(p2);

personRepo.save(p3);

}

如图,测试用例已经建立起了电影与导演、演员之间的联系

(3)findMovieByTitle

@Test

public void testfindByTitle() {

Movie movie = movieRepo.findByTitle("罗曼蒂克消亡史");

}

查询出相应的结果符合预期

{

"id":26,

"title":"罗曼蒂克消亡史",

"released":"2016"

}

(4)findPersonByName

@Test

public void testfindByName() {

Person person = personRepo.findByName("章子怡");

}

这里需注意的是,该演员对应了两部电影,查询个人信息的同时应该包含两部电影

{

"id":27,

"name":"章子怡",

"born":"1979",

"actors":[

{

"id":25,

"title":"无问西东",

"released":"2018"

},

{

"id":26,

"title":"罗曼蒂克消亡史",

"released":"2016"

}

]

}

查询结果也符合预期

还有很多findAll、delete就不在一一列举了,至此springBoot与neo4j的简单整合就完成了

demo源码点击下载

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值