目录

一、安装

二、CQL使用

三、Springboot(2.4以上版本)整合neo4j 

四、使用过程中的问题

1、自定义查询,cql无法接收变量

2、使用依赖去操作neo4j只有return才会执行

3、neo4j和mysql事务冲突

补充


一、安装

1、首先要配置jdk,默认电脑中有jdk

2、访问neo4j官网选择需要的版本进行下载,一般选择社区版就可以

Neo4j Download Center - Neo4j Graph Data Platform

jquery 页面 load jquery 页面 neo4j_jquery 页面 load

 3、下载后的压缩包解压到想要路径(路径不要有中文)

 4、启动neo4j

在命令行中切换到安装目录的bin目录下,输入命令 ./neo4j start

jquery 页面 load jquery 页面 neo4j_neo4j_02

 启动完就可以在浏览器中输入,会出现以下登录页面,初始密码都是neo4j,然后会引导修改密码

jquery 页面 load jquery 页面 neo4j_neo4j_03


二、CQL使用

1、创建节点

语法:create (别名:节点名 {属性名:属性值})

create (n:`西游记` {name:'菩提老祖'})

jquery 页面 load jquery 页面 neo4j_属性值_04

2、创建关系

语法:CREATE (别名:节点名 {属性名:属性值})-[别名:关系名]->(别名:节点名 {属性名:属性值})

CREATE (n:`西游记` {name:'孙悟空'})-[r:师傅]->(m:`西游记` {name:'菩提老祖'})

jquery 页面 load jquery 页面 neo4j_neo4j_05

2.1、从已有节点创建关系:先查到节点再创建关系

MATCH (n:`西游记` {name:"孙悟空"}),(m:`西游记` {name:"牛魔王"}) create (n)-[r:`义兄`]->(m)

jquery 页面 load jquery 页面 neo4j_jquery 页面 load_06

3、查询节点

MATCH (n:`西游记` {name:"孙悟空"}) return n

也可以使用where条件 MATCH (n:`西游记`) WHERE n.name="孙悟空" RETURN n

jquery 页面 load jquery 页面 neo4j_Data_07

4、set属性赋值

MATCH (n:`西游记` {name:"孙悟空"}) set n.skill='七十二变' return n

jquery 页面 load jquery 页面 neo4j_neo4j_08

5、删除节点

语法:MATCH (别名:节点名 {属性名:属性值}) delete 别名(先找到节点再删除)

MATCH (n:`西游记` {name:"菩提老祖"}) delete n

直接删除节点会报错,因为这个节点存在关系,需要先删除关系

jquery 页面 load jquery 页面 neo4j_spring boot_09

5.1、删除关系

MATCH (n:`西游记` {name:"菩提老祖"})<-[r]-(m) delete r

jquery 页面 load jquery 页面 neo4j_jquery 页面 load_10

jquery 页面 load jquery 页面 neo4j_spring boot_11

6、其他关键字ORDER BY、UNION、UNION ALL、IN、LIMIT、DISTINCT 等与mysql使用一样

6.1、in查询

注:in查询的元素是用中括号[ ]包括

MATCH (n:`西游记`) WHERE id(n) IN [1,2] RETURN n

jquery 页面 load jquery 页面 neo4j_jquery 页面 load_12

7、索引

7.1、创建索引

jquery 页面 load jquery 页面 neo4j_spring boot_13

7.2、删除索引

jquery 页面 load jquery 页面 neo4j_neo4j_14

7.3、UNIQUE唯一约束

jquery 页面 load jquery 页面 neo4j_属性值_15

上面创建了唯一约束,再创建存在的节点就会报错

jquery 页面 load jquery 页面 neo4j_Data_16

删除唯一约束

jquery 页面 load jquery 页面 neo4j_属性值_17

8、数据库备份

8.1、关闭neo4j

./neo4j stop

jquery 页面 load jquery 页面 neo4j_Data_18

8.2、备份(备份文件夹需要存在)

./neo4j-admin dump --database "neo4j" --to=/Users/elroyelroy/soft/neo4j-community-4.4.15/backup/graph_backup.dump

8.3恢复

./neo4j-admin load --from=/Users/elroyelroy/soft/neo4j-community-4.4.15/backup/graph_backup.dump

--database "neo4j" --force

三、Springboot(2.4以上版本)整合neo4j 

1、yml配置文件添加配置

spring:
  neo4j:
    uri: bolt://localhost:7687
    authentication:
      username: neo4j
      password: 123456
  data:
    neo4j:
      database: neo4j

2、pom文件引入依赖

<!-- neo4j 驱动 -->
        <dependency>
            <groupId>org.neo4j.driver</groupId>
            <artifactId>neo4j-java-driver</artifactId>
        </dependency>
        <!-- neo4j 操作实体注解需要 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-neo4j</artifactId>
        </dependency>

3、创建实体类和dao层

3.1、创建实体类


@Node("Star"):这个注解表示节点的名称


@Id @GeneratedValue:id自动生成策略


@Data
@NoArgsConstructor
@AllArgsConstructor
@Node("Star")
public class Star implements Serializable {
    private static final long serialVersionUID = 1L;

    @Id
    @GeneratedValue
    private Long id;

    private String name;
}

3.2、创建Repository

这边需要继承ReactiveNeo4jRepository 来操作neo4j

@Repository
public interface StarRepository extends ReactiveNeo4jRepository<Star, Long> {

}

3.3、测试

注:return的值如果一个对象要用Mono<>返回,如果是个列表用Flux<>返回

@Resource
    private StarRepository starRepository;

    @GetMapping("/all")
    public Flux<Star> all() {
        return starRepository.findAll();
    }

    
    @GetMapping("/add")
    public Mono<Star> add() {
        Star star = new Star();
//        Star.setId(1); // 修改时设置id就会修改对应id下面的值
        star.setName("蔡徐坤");
        return starRepository.save(star);
    }


    @GetMapping("/delete")
    public Mono<Void> delete() {
        return starRepository.deleteAll();
    }

四、使用过程中的问题

1、自定义查询,cql无法接收变量

使用@Query注解传入cql语句

这里接收动态参数时,网上找了很多种方式,{name},{0},$name,$0 等都会报错,自己测试是加个@Param 注解配合$ 才可以接收传进来的参数

@Query("MATCH (n:Star{name:$name}) RETURN m")
    Mono<Star> findStarByName(@Param("name") String name);

2、使用依赖去操作neo4j只有return才会执行

在进行neo4j操作时,对数据库的增删改查操作都必须放在return行才会执行,这样会导致我们有些业务操作,或者多个节点操作无法在一个方法里面实现。

解决办法:

1)使用block()方法

在操作的最后调用.block()方法,会立即提交这个事务,并且返回这个对象的信息。

jquery 页面 load jquery 页面 neo4j_jquery 页面 load_19

 list操作是blockFirst()和blockLast()。

jquery 页面 load jquery 页面 neo4j_spring boot_20

这里list的操作也会全部提交执行,但是它只会返回第一个对象或者最后一个对象,如果只是想提交这个操作可以使用,如果有业务需要对提交后的列表信息进行操作这边就不建议使用。

2)Neo4jTemplate的使用

引入Neo4jTemplate,这边的操作就跟mybatisplus的操作无异,直接进行保存,并且保存后这个对象就会有保存后生成后的id等信息。

jquery 页面 load jquery 页面 neo4j_jquery 页面 load_21

jquery 页面 load jquery 页面 neo4j_Data_22

要注意的是,neo4jTemplate的返回值都是我们所操作的对象和List,这样使得我们在进行业务操作的时候更顺手,对比Mono<>和Flux<>简直不要太友好,从这一点来说,个人还是更喜欢使用neo4jTemplate。

jquery 页面 load jquery 页面 neo4j_Data_23

3、neo4j和mysql事务冲突

在引入neo4j之后,一些加了@Transactional注解使用mysql事务的方法就会报错,有的甚至可能项目启动就报错了

jquery 页面 load jquery 页面 neo4j_neo4j_24

这是因为在引入了Neo4J依赖库之后,transactionManager就变成了Neo4jTransactionManager,所以就要去修改默认事务。

// 修改默认事务,加载了Neo4J依赖库之后,transactionManager变成Neo4jTransactionManager,不增加此处,启动会报错,Mysql无法使用。
    @Bean("transactionManager")
    @Primary
    public DataSourceTransactionManager transactionManager(DataSource dataSource) {
        return new DataSourceTransactionManager(dataSource);
    }

    // neo4j事务
    @Bean(ReactiveNeo4jRepositoryConfigurationExtension.DEFAULT_TRANSACTION_MANAGER_BEAN_NAME)
    public ReactiveTransactionManager reactiveTransactionManager(
            Driver driver,
            ReactiveDatabaseSelectionProvider databaseNameProvider) {
        return new ReactiveNeo4jTransactionManager(driver, databaseNameProvider);
    }

 

补充

Springboot整合也可以查看官方文档