问题描述
我正在尝试创建具有CURRENT/PREVIoUS
关系的节点的链表,类似于下图。
我不确定我的解决方案是否是处理这种情况的正确方法,但是要实现这一点,我用一种方法创建了两个节点来填充新消息,如下所示:
@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
关系,我的解决方案将输出显示为:
所以问题是:
解决方法
我发现了缺失的难题,即脱离了供应商关系。我不知道为什么我事先假设应该通过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。我仍然有疑问,因为我不确定这是否是处理这种情况的好方法,因此,如果您知道更好的解决方案,请继续进行发布,我们可以随时交换“最佳答案”:)