如何解决Spring JPA 基于类的投影和嵌套投影
我正在尝试使用基于类的投影来填充数据,但似乎 Spring JPA 不支持嵌套投影。这是我的实体类:
public class Category extends BaseEntity<String> {
@Column(unique = true)
private String code;
private String externalCode;
@ManyToOne(cascade = CascadeType.ALL)
private Category parent;
..
}
这是相同的 DTO 类:
@Data
@NoArgsConstructor
@AllArgsConstructor
@Builder
public class CategoryDto implements BaseDto,Serializable {
private String code;
private String externalCode;
private CategoryDto parent;
..
}
我的CategoryRepository
@Query("select new com.easycart.core.data.category.CategoryDto(c.id,c.code,c.externalCode,c.SEOMeta,c.createdAt,c.updatedAt,c.parent) FROM Category c where c.code = :code")
CategoryDto findCategoryByCode(String code);
我不能使用 c.parent
,因为类型是 Category
而不是 CategoryDto
,我也没有找到任何使用嵌套投影来填充父信息的选项给定的实体。有人可以帮我解答以下问题吗?
- 有没有办法使用基于类的投影来实现这一点?
- 我是否需要回退到单独填写父信息的选项(我不需要在初始加载时为父提供大量信息。)。
- 还有其他方法可以实现这一目标吗?我不想使用基于接口的投影作为初始测试,这表明它与基于类的投影相比非常慢。
解决方法
在 Spring Data JPA 中没有开箱即用的支持。
实现这一点的方法是使用 constructor expressions 和 ResultTransformer
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。