基本信息
源码名称:springboot+neo4j
源码大小:11.21M
文件格式:.rar
开发语言:Java
更新时间:2020-09-25
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 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

总结

     本次大概写了下我认为的比较简单的配置方式,在此之前小编还尝试了配置类的方式,比较繁琐这次就不做介绍了,感谢您的阅读~~