当应用程序基于Spring Boot时,不考虑定义的实体图。相反,在JUnit测试期间一切正常。

领域非常简单:书籍及其类别(多对多关系)。
书本类:

@Entity
@NamedEntityGraph(name = "Book.summary",
attributeNodes = { @NamedAttributeNode("book_id"), @NamedAttributeNode("title")})

public class Book {
@Id
@GeneratedValue(strategy= GenerationType.AUTO)
private Long book_id;

private String title;

@ManyToMany(cascade = CascadeType.ALL)
@JoinTable(name = "BOOK_CATEGORY",
        joinColumns = @JoinColumn(name = "book_id", referencedColumnName = "book_id"),
        inverseJoinColumns = @JoinColumn(name = "category_id", referencedColumnName = "category_id"))
private List<Category> categories;


类别类别:

@Entity
public class Category {
@Id
@GeneratedValue(strategy= GenerationType.AUTO)
private Long category_id;

private String name;

@ManyToMany(mappedBy = "categories")
private List<Book> books;


JPA存储库及其使用创建的实体图的方法:

@Component
@Repository
public interface BookJpaRepository extends JpaRepository<Book, Long> {
@Override
@EntityGraph(value = "Book.summary", type = EntityGraph.EntityGraphType.FETCH)
List<Book> findAll(); }


REST控制器中的用法:

@RequestMapping("/books")
@ResponseBody
public List<Book> getBooksSummary() {
    return bookJpaRepository.findAll();
}


启动Spring Boot(mvn spring-boot:run)并导航到http://localhost:8080/books书后,将显示书,但它们具有各自的类别(并且由于无限递归而引发异常:books-> Categories-> books-> Categories->)。 ..)。

测试中的相同代码(使用SpringJUnit4ClassRunner运行)按预期工作,并且正确识别了实体图。例如,下面的代码没有显示类别,因为正如预期的那样,存在延迟的初始化:

@Test
public void testEntityGraph() {
    List<Book> all = bookJpaRepository.findAll();

    System.out.println(all.get(0).getCategories());
}


有关在Spring Boot上运行应用程序时如何使实体图正常工作的任何建议?

最佳答案

正如Rae Burawes(感谢!)在评论中指出的,此行为的原因是序列化。
为了处理Jackson序列化程序的数据获取,我们可以使用以下注释:
-com.fasterxml.jackson.annotation.JsonIdentityInfo-上课/上课
-com.fasterxml.jackson.annotation.JsonManagedReferencecom.fasterxml.jackson.annotation.JsonIgnore-现场

可以在this tutorial中找到更多信息。

09-13 04:52