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

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

相关推荐
阿琦学代码28 分钟前
Spring Cloud(微服务) 概述
后端·spring·spring cloud
GreatSQL1 小时前
GreatSQL CTE 查询报告临时表找不到问题解析
后端
用户68545375977691 小时前
🎛️ JVM调优秘籍:把你的Java程序调教成性能怪兽!
后端
Asthenia04121 小时前
一次空值查询的“陷阱”排查:为什么我的接口不返回数据了?
后端
回家路上绕了弯1 小时前
慢查询优化全攻略:从定位根源到落地见效的实战指南
后端·性能优化
长存祈月心1 小时前
Rust HashSet 与 BTreeSet深度剖析
开发语言·后端·rust
长存祈月心1 小时前
Rust BTreeMap 红黑树
开发语言·后端·rust
京东云开发者1 小时前
提供方耗时正常,调用方毛刺频频
后端
用户68545375977691 小时前
🐌 数据库慢查询速成班:让你的SQL从蜗牛变火箭!
后端
cipher1 小时前
用 Go 找预测市场的赚钱机会!
后端·go·web3