前言
小编最近的工作中遇到了一些知识图谱的工作,自然就用到了图数据库,这一NoSQL 数据库可以很好的展示节点之间的关联关系,对于一些图谱的关系操作是很好的选择哦~,下面来介绍下 Springboot 中如何集成Neo4J。
正文
Neo4j 概览 ( 这张图超喜欢)
NEO4J 学习
neo4j官网介绍
spring-data-neo4j官网介绍
Pom文件中引入依赖
Spring生态中Spring-data部分不仅仅提供了Spring-data-jpa , 也提供了Spring-data-neo4j 支持spring和 neo4j的完美融合,pom.xml 文件中依赖如图:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-neo4j</artifactId>
</dependency>
yml文件中配置连接属性
spring:
data:
neo4j:
uri: bolt://localhost:7687
username: neo4j
password: neo4j
建立NodeEntity
( 有点类似于Mysql中的table 映射的对象类,mysql中叫做ORM,neo4j中叫做OGM [object graph mapping])
【节点的标签实体】
@NodeEntity
@Builder
@Data
public class SupplyGraph {
@Id
@GeneratedValue
private Long id;
/**
* 供应商名称
*/
private String name;
}
【关系实体】
# 供应关系(公司节点和供应商节点节点是供应关系)
@Data
@Builder
@RelationshipEntity(type = "supply")
public class SupplyRelationship {
@Id
@GeneratedValue
private Long id;
private String indexName;
//关系的一端节点是 公司节点
@StartNode
private CompanyGraph company;
//关系的另一端节点是 供应商节点
@EndNode
private SupplyGraph supply;
//下面是关系的属性
/**
* 采购占比
*/
private String scale;
/**
* 采购金额
*/
private String amount;
}
编写Repository
// 节点Repository
public interface SupplyGraphRepository extends Neo4jRepository<SupplyGraph,Long> {}
// 关系Repository
public interface SupplyRelationshipRepository extends Neo4jRepository<SupplyRelationship, Long> { }
编写Service
实现功能: 添加公司节点到图数据库中,添加供应商节点到图数据库中,添加供应关系到图数据库中;
public void testSave(){
……
//采购占比
String scale = "47.14%";
// 采购金额
String amount =“18923.42” ;
//供应商名称
String name = "常州常电及其关联公司";
//公司实体部分及添加公司节点部分省略...(companyGraph)
SupplyGraph supplyGraph = SupplyGraph.builder().name(name).build();
//添加供应商节点
supplyGraphRepository.save(supplyGraph);
String indexName = companyGraph.getFullName() + "-" + supplyGraph.getName();
//供应商关系
SupplyRelationship supplyRelationship =
SupplyRelationship.builder().company(companyGraph).supply(supplyGraph).amount(amount).scale(scale).indexName(indexName).build();
//添加供应关系
supplyRelationshipRepository.save(supplyRelationship);
……
}
运行程序,查看结果
可以看到红框中有新增的两个实体和关系,执行成功!
疑问 & 讨论
小编在生产环境用到了Neo4j 集群,在配置集群地址时大家都是怎么配置的呢? 欢迎大家下方留言共同探讨~
生效的方式(感觉neo4j cluster address 配置的怪怪的):
spring:
data:
neo4j:
# leader:ip1 follower:ip2 ,ip3
uri: bolt://ip1:7687
uris: bolt://ip2:7687,bolt://ip3:7687
username: neo4j
password:pro
失败的方式:
spring:
data:
neo4j:
# leader:ip1 follower:ip2 ,ip3
uris: bolt://ip1:7687,bolt://ip2:7687,bolt://ip3:7687
username: neo4j
password:pro
总结
本次大概写了下我认为的比较简单的配置方式,在此之前小编还尝试了配置类的方式,比较繁琐这次就不做介绍了,感谢您的阅读~~