Spring Data JPA 是否有可能做到这一点?像这样:
public interface UserDao extends CrudRepository<User, Long> {
@EntityGraph(value = :graphName, type = EntityGraph.EntityGraphType.LOAD)
@Query(value = "SELECT DISTINCT u FROM User u")
List<User> findAllWithDetailsByGraphName(@Param(value="graphName") String graphName);
}
能够在运行时将 graphName 传递给方法并使用一组需要的集合调用加载?此构造不起作用,产生编译时错误。围绕它的任何游戏也失败了......
因此,我在 User 类中有多个集合,我想按条件加载它们;
@Entity
@Table(name="user")
@NamedEntityGraphs({
@NamedEntityGraph(name = "User.details", attributeNodes = {
@NamedAttributeNode("phones"), @NamedAttributeNode("emails"), @NamedAttributeNode("pets")}),
@NamedEntityGraph(name = "User.phones", attributeNodes =
{@NamedAttributeNode("phones")}),
@NamedEntityGraph(name = "User.emails", attributeNodes =
{@NamedAttributeNode("emails")}),
@NamedEntityGraph(name = "User.pets", attributeNodes =
{@NamedAttributeNode("pets")})
})
public class User {
@Id
@GeneratedValue(strategy= GenerationType.AUTO, generator="native")
@GenericGenerator(name = "native", strategy = "native")
@Column(name="user_id")
private Long userId;
@Column(name="name")
private String name;
// more fields omitted
@OneToMany(mappedBy = "user", cascade = CascadeType.ALL)
private Set<Phone> phones;
@OneToMany(mappedBy = "user", cascade = CascadeType.ALL)
private Set<Email> emails;
@OneToMany(mappedBy = "user", cascade = CascadeType.ALL)
private Set<Pet> pets;
}
现在,我只需隐式声明所有方法,如下所示:
@EntityGraph(value = "User.phones", type = EntityGraph.EntityGraphType.LOAD)
@Query(value = "SELECT DISTINCT u FROM User u")
List<User> findAllWithPhones();
谢谢你的建议!