嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们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
 
总结
本次大概写了下我认为的比较简单的配置方式,在此之前小编还尝试了配置类的方式,比较繁琐这次就不做介绍了,感谢您的阅读~~