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

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

相关推荐
雪隐13 分钟前
AI股票小助手05-用 Flask 把 MiniQMT 变成 REST API
人工智能·后端
道友可好24 分钟前
Spec Kit:GitHub 官方出品,规范即代码
前端·人工智能·后端
货拉拉技术28 分钟前
货拉拉标注平台-拉拉标注
后端·架构
fox_lht31 分钟前
第十四章 一个输入和输出项目:构建一个命令行程序
开发语言·后端·rust
qq_3564086633 分钟前
Neo4j RPM 安装与多实例配置说明
neo4j
fox_lht41 分钟前
14.2.读文件
开发语言·后端·rust
用户3058759549311 小时前
Docker 环境下 MySQL 读写分离实践:ProxySQL + 主从复制
后端
用户298698530141 小时前
Java 操作 Word 文档:常见编辑功能实现
java·后端
XovH1 小时前
第 40 篇 k8s之Helm:编写自定义 Helm Chart
后端
曾几何时`1 小时前
Go(四)Channel
开发语言·后端·golang