嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元微信扫码支付:2 元
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
前言
小编最近的工作中遇到了一些知识图谱的工作,自然就用到了图数据库,这一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>
- 1
- 2
- 3
- 4
yml文件中配置连接属性
spring: data: neo4j: uri: bolt://localhost:7687 username: neo4j password: neo4j
- 1
- 2
- 3
- 4
- 5
- 6
建立NodeEntity
( 有点类似于Mysql中的table 映射的对象类,mysql中叫做ORM,neo4j中叫做OGM [object graph mapping])
【节点的标签实体】
@NodeEntity @Builder @Data public class SupplyGraph { @Id @GeneratedValue private Long id; /** * 供应商名称 */ private String name; }
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
【关系实体】
# 供应关系(公司节点和供应商节点节点是供应关系) @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; }
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
编写Repository
// 节点Repository public interface SupplyGraphRepository extends Neo4jRepository<SupplyGraph,Long> {} // 关系Repository public interface SupplyRelationshipRepository extends Neo4jRepository<SupplyRelationship, Long> { }
- 1
- 2
- 3
- 4
编写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); …… }
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
运行程序,查看结果
可以看到红框中有新增的两个实体和关系,执行成功!
疑问 & 讨论
小编在生产环境用到了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
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
失败的方式:
spring: data: neo4j: # leader:ip1 follower:ip2 ,ip3 uris: bolt://ip1:7687,bolt://ip2:7687,bolt://ip3:7687 username: neo4j password:pro
- 1
- 2
- 3
- 4
- 5
- 6
- 7
总结
本次大概写了下我认为的比较简单的配置方式,在此之前小编还尝试了配置类的方式,比较繁琐这次就不做介绍了,感谢您的阅读~~