弹簧数据neo4j中的当前/上一个节点关系LinkedList

问题描述

我正在尝试创建具有CURRENT/PREVIoUS关系的节点的链表,类似于下图。

this picture

我不确定我的解决方案是否是处理这种情况的正确方法,但是要实现这一点,我用一种方法创建了两个节点来填充新消息,如下所示:

@Builder
@Data
@NoArgsConstructor
public class Person {

    @Id
    @GeneratedValue
    private Long id;
    private String name;

    @Relationship(type = "LATEST")
    private Message message;
    
    void newMessage(Message newMessage) {
        newMessage.setPrevIoUs(message);
        message = newMessage;
    }
}
    
@Builder
@Data
@NoArgsConstructor
public class Message {
    @Id
    @GeneratedValue
    private Long id;
    private String text;

    @Relationship(type = "PREVIoUS")
    private Message prevIoUs;
}

我还创建了一个示例代码来测试此解决方案:

@SpringBootApplication
public class NewsFeedApplication {

    public static void main(String[] args) {
        SpringApplication.run(NewsFeedApplication.class,args);
    }

    @Bean
    CommandLineRunner init(PersonRepository personRepository) {
        return args -> {
            Person personToAdd1 = Person.builder().name("John").build();
            personToAdd1.newMessage(Message.builder().text("first message").build());
            personToAdd1.newMessage(Message.builder().text("second message").build());
            personToAdd1.newMessage(Message.builder().text("third message").build());

            personRepository.save(personToAdd1);

            personToAdd1.newMessage(Message.builder().text("New message.").build());

            personRepository.save(personToAdd1);
        };
    }
}

我觉得我已经接近了,但是我不知道如何重置以前的CURRENT关系,我的解决方案将输出显示为:

invalid solution

所以问题是:

  • 如果我的方法还行,那么如何删除以前的CURRENT关系。
  • 如果这种方法错误的,我该如何正确地为节点实现具有CURRENT / PREVIoUS关系的链表。

解决方法

我发现了缺失的难题,即脱离了供应商关系。我不知道为什么我事先假设应该通过spring数据存储库的“保存”方法自动删除此关系。

工作解决方案:

public interface PersonRepository extends Neo4jRepository<Supplier,Long> {

    @Query("MATCH (n:Person {name: $name})-[r:LATEST]->() DELETE r")
    void detachLatestFromPerson(String name);
}
    void newMessage(PersonRepository personRepository,Message newMessage) {
        personRepository.detachLatestFromPerson(name);
        newMessage.setPrevious(message);
        message = newMessage;
    }

PS。我仍然有疑问,因为我不确定这是否是处理这种情况的好方法,因此,如果您知道更好的解决方案,请继续进行发布,我们可以随时交换“最佳答案”:)