Spring data rest 使用一个 crud 存储库管理所有实体
Spring data rest managing all entities with one crud repository
我想知道在 spring 数据剩余中是否可以使用一个 crud 存储库管理多个实体。
示例:
图书馆实体
@Entity
public class Library {
@Id
@GeneratedValue
private long id;
@Column
private String name;
@OneToMany(mappedBy = "library")
private List<Book> books;
}
图书实体
@Entity
public class Book {
@Id
@GeneratedValue
private long id;
@Column(nullable=false)
private String title;
@ManyToOne
@JoinColumn(name="library_id")
private Library library;
}
我的要求是
public interface LibraryRepository extends CrudRepository<Library, Long> { }
是只有这个存储库来管理图书馆和图书实体。
我试过插入,到目前为止效果很好。但这种方法不支持其他操作。是否有任何其他方法而不是使用两个 crud 存储库来执行此操作。
你不能简单地做到这一点,因为将为每个存储库创建一个 bean,并且应该使用定义的实体类型实例化这个 bean
当然可以。只需像这样更正您的图书馆:
@OneToMany(mappedBy = "library", cascade = CascadeType.ALL, orphanRemoval = true)
private List<Book> books;
然后你可以create/update你的图书馆和它的书有这个负载:
{
"name": "library1",
"books": [
{
"title": "book1"
},
{
"title": "book2"
}
]
}
Spring 数据作者的代码 example。
我的example.
我想知道在 spring 数据剩余中是否可以使用一个 crud 存储库管理多个实体。
示例:
图书馆实体
@Entity
public class Library {
@Id
@GeneratedValue
private long id;
@Column
private String name;
@OneToMany(mappedBy = "library")
private List<Book> books;
}
图书实体
@Entity
public class Book {
@Id
@GeneratedValue
private long id;
@Column(nullable=false)
private String title;
@ManyToOne
@JoinColumn(name="library_id")
private Library library;
}
我的要求是
public interface LibraryRepository extends CrudRepository<Library, Long> { }
是只有这个存储库来管理图书馆和图书实体。
我试过插入,到目前为止效果很好。但这种方法不支持其他操作。是否有任何其他方法而不是使用两个 crud 存储库来执行此操作。
你不能简单地做到这一点,因为将为每个存储库创建一个 bean,并且应该使用定义的实体类型实例化这个 bean
当然可以。只需像这样更正您的图书馆:
@OneToMany(mappedBy = "library", cascade = CascadeType.ALL, orphanRemoval = true)
private List<Book> books;
然后你可以create/update你的图书馆和它的书有这个负载:
{
"name": "library1",
"books": [
{
"title": "book1"
},
{
"title": "book2"
}
]
}
Spring 数据作者的代码 example。
我的example.