springboot整合neo4j--采用Neo4jClient和Neo4jTemplate方式

1.背景

看了spring-boot-starter-data-neo4j的源码之后发现,该starter内已经实现了Neo4jClientNeo4jTemplate ,我们只需要使用Autowire就能直接使用它操作neo4j。

Neo4jClient方式与我的另一篇springboot整合neo4j-使用原生cypher Java API博客方式一样,Neo4jTemplate则与SpringBoot 整合 Neo4j博客实现方式类似,但比这篇博客要简单。

2.实现

2.1引入maven

springboot版本为2.6,低版本的可能不支持。

java 复制代码
<dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-data-neo4j</artifactId>
</dependency>

该包里面已经包含了neo4j-java-driver,故不需要额外引入。

完整maven文件与我的另一篇博客内容一致springboot整合neo4j-使用原生cypher Java API

2.2配置

因为该方式是springboot starter方式,所以配置文件的配置路径是固定的。

java 复制代码
spring.data.neo4j.uri=bolt://127.0.0.1:7687
spring.data.neo4j.username=neo4j
spring.data.neo4j.password=123456

2.3测试

java 复制代码
package com.win.chaos;

import com.win.chaos.model.neo4j.Neo4jGraph;
import org.junit.jupiter.api.Test;
import org.neo4j.driver.*;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.neo4j.core.Neo4jClient;
import org.springframework.data.neo4j.core.Neo4jTemplate;
import javax.annotation.Resource;

@SpringBootTest
public class Neo4jTest {

    @Resource
    private Neo4jClient neo4jClient;
    @Resource
    private Neo4jTemplate neo4jTemplate;

    @Test
    public void test() {
        String cypher = "MATCH p=()-[r:`持股`]->() RETURN p LIMIT 25";
        Driver driver = GraphDatabase.driver("bolt://127.0.0.1:7687", AuthTokens.basic("neo4j", "123456"));
        Session session = driver.session();
        //Transaction ts = session.beginTransaction();
        //Result result = ts.run(cypher);
        Result result = session.run(cypher);
        Neo4jGraph graph = Neo4jGraph.parse(result);
        int size = graph.getNodes().size();
    }

    @Test
    public void testNeo4jClient() {
        String cypher = "MATCH p=()-[r:`持股`]->() RETURN p LIMIT 25";
        String addQL = "CREATE (o:people {name:\"里斯\",id:32435})"
        QueryRunner runner = neo4jClient.getQueryRunner();
        Result result = runner.run(cypher);
        Neo4jGraph graph = Neo4jGraph.parse(result);
        int size = graph.getNodes().size();

		runner.run(addQL);
    }

    @Test
    public void testNeo4jTemplate() {
        String cypher = "MATCH p=()-[r:`持股`]->() RETURN p LIMIT 25";
        QueryRunner runner = neo4jTemplate.findAll();//需要传入参数
        Result result = runner.run(cypher);
        Neo4jGraph graph = Neo4jGraph.parse(result);
        int size = graph.getNodes().size();
    }
}

上述代码中的解析查询结果的代码Neo4jGraph.parse与我的另一篇博客内容一致springboot整合neo4j-使用原生cypher Java API

完整代码:本博客完整代码

相关推荐
武子康31 分钟前
大数据-190 Filebeat→Kafka→Logstash→Elasticsearch 实战
大数据·后端·elasticsearch
野蛮人6号33 分钟前
黑马微服务报错以及解决前23节课
spring boot·微服务·mybatis
西京刀客43 分钟前
go语言-切片排序之sort.Slice 和 sort.SliceStable 的区别(数据库分页、内存分页场景注意点)
后端·golang·sort·数据库分页·内存分页
计算机毕设VX:Fegn08951 小时前
计算机毕业设计|基于springboot + vue汽车销售系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·汽车·课程设计
IT枫斗者1 小时前
Java 开发实战:从分层架构到性能优化(Spring Boot + MyBatis-Plus + Redis + JWT)
java·spring boot·sql·mysql·性能优化·架构
聆风吟º1 小时前
【Spring Boot 报错已解决】Spring Boot项目启动报错 “Main method not found“ 的全面分析与解决方案
android·spring boot·后端
Rover.x1 小时前
Arthas内存泄露排查
java·后端
艺杯羹1 小时前
掌握Spring Boot配置艺术:从YAML基础到实战进阶
java·spring boot·后端·yaml
喵叔哟1 小时前
12.云平台部署
后端·.netcore
rannn_1112 小时前
【SQL题解】力扣高频 SQL 50题|DAY1
后端·sql·题解