使用Neo4j Java Driver操作Neo4j

本文介绍如何使用Neo4j Java Driver连接并操作Neo4j数据库,包括配置Maven依赖、编写Java代码进行节点创建及查询等步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文是neo4j的官方文档https://neo4j.com/developer/java/#_the_example_project的翻译和整理。
Neo4j Java driver是Neo4j官方支持的操作Neo4j数据库的driver,基于二进制协议(英文是binary protocol,但是并不太明白这个二进制协议是什么)。该driver方便简洁,还是挺好用的。
要使用这个driver,首先需要在maven项目中的pom.xml中引入

    <dependency>
        <groupId>org.neo4j.driver</groupId>
        <artifactId>neo4j-java-driver</artifactId>
        <version>1.1.2</version>
    </dependency>

java代码则如下:

import org.neo4j.driver.v1.*;

import static org.neo4j.driver.v1.Values.parameters;

Driver driver = GraphDatabase.driver( "bolt://localhost:7687", AuthTokens.basic( "neo4j", "neo4j" ) );
Session session = driver.session();

session.run( "CREATE (a:Person {name: {name}, title: {title}})",
        parameters( "name", "Arthur", "title", "King" ) );

StatementResult result = session.run( "MATCH (a:Person) WHERE a.name = {name} " +
                                      "RETURN a.name AS name, a.title AS title",
        parameters( "name", "Arthur" ) );
while ( result.hasNext() )
{
    Record record = result.next();
    System.out.println( record.get( "title" ).asString() + " " + record.get( "name" ).asString() );
}

session.close();
driver.close();

然后运行Neo4j,运行java程序。
刚开始在配置GraphDatabase.driver的时候,把端口设置成了7474,出现错误:

Exception in thread "main" org.neo4j.driver.v1.exceptions.ClientException: Unable to process request: Unrecognized SSL message, plaintext connection?

然后在http://stackoverflow.com/questions/39722278/how-can-i-get-java-and-neo4j-to-work-in-eclipse上面找到解答,原来是7474是http端口,而bolt端口是8687。其实也不用像这篇回答说的修改conf文件,不过猜想也许修改conf文件是为了别的ip访问。直接运行程序发现出现错误,大概意思是说:“如果你是第一次运行Neo4j,请先初始化密码”等等,我才想起来第一次登陆的时候需要初始化,只需登陆localhost:7474然后初始化密码即可。最后,运行后的数据库多了一个节点:
这里写图片描述

### Spring MVC 集成 Neo4j Java Driver 实现对 Neo4j 数据库的操作 #### 一、添加 Maven 依赖 为了在 Spring MVC 中使用 `neo4j-java-driver` 来操作 Neo4j 数据库,首先需要引入相应的 Maven 依赖。根据最新版本的信息,在项目的 pom.xml 文件中加入如下配置: ```xml <dependency> <groupId>org.neo4j.driver</groupId> <artifactId>neo4j-java-driver</artifactId> <version>1.5.0</version> </dependency> ``` 此部分描述了如何通过Maven构建工具向项目添加Neo4j驱动程序所需的依赖项[^1]。 #### 二、创建 Neo4j 连接池配置类 接着要编写一个用于初始化和管理与 Neo4j 数据库之间连接的对象工厂 Bean 定义。可以创建一个新的 Java 类来完成这项工作,比如命名为 `Neo4jConfig.java`: ```java import org.neo4j.driver.AuthTokens; import org.neo4j.driver.GraphDatabase; @Configuration public class Neo4jConfig { @Value("${spring.data.neo4j.uri}") private String uri; @Value("${spring.data.neo4j.username}") private String username; @Value("${spring.data.neo4j.password}") private String password; @Bean(destroyMethod = "close") public Driver driver() { return GraphDatabase.driver(uri, AuthTokens.basic(username, password)); } } ``` 这段代码展示了如何利用Spring框架中的`@Configuration`注解定义配置类,并通过注入属性的方式读取应用配置文件内的数据库访问参数,从而建立到目标图数据库的服务端口链接[^2]。 #### 三、编写数据访问层 DAO 接口及其实现 对于具体的 CRUD (Create Read Update Delete) 功能,则可以通过设计专门的数据访问对象(DAO),即接口以及其实现来进行封装。这里给出一个简单的例子作为参考: ```java @Repository public interface PersonRepository extends BaseRepository<Person, Long> {} @Service @Transactional(readOnly=true) public class PersonServiceImpl implements PersonService { @Autowired private PersonRepository personRepo; // ... other methods ... @Override public List<Person> findAllPeople(){ Session session = sessionFactory.openSession(); try{ Result result = session.run("MATCH (p:Person) RETURN p"); List<Person> peopleList = new ArrayList<>(); while(result.hasNext()){ Record record = result.next(); Node node = record.get("p").asNode(); Person person = convertToEntity(node); peopleList.add(person); } return peopleList; } finally { session.close(); } } private Person convertToEntity(Node node){ Person entity = new Person(); entity.setId((Long)node.id()); entity.setName(node.get("name").asString()); // set more fields... return entity; } } ``` 上述示例说明了怎样基于面向切面编程(AOP)特性标记事务边界并执行基本查询语句以检索存储于图形结构化信息集合里的实体记录。 #### 四、控制器 Controller 层处理 HTTP 请求映射 最后一步是在 Web 控制器里设置 RESTful API 的路由规则以便客户端能够发送请求并与服务端交互。下面是一个可能的实现方式: ```java @RestController @RequestMapping("/api/people") public class PeopleController { @Autowired private PersonService personService; @GetMapping("") public ResponseEntity<List<Person>> getAllPersons(){ List<Person> persons = personService.findAllPeople(); if(!persons.isEmpty()) return new ResponseEntity<>(persons, HttpStatus.OK); else throw new ResourceNotFoundException("No data found."); } } ``` 该片段解释了REST风格API的设计模式下如何接收GET类型的HTTP调用来响应前端页面或其他应用程序发起的人际关系网络节点列表展示需求。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值