我的问题比第一眼看到的要复杂得多。让我试着解释一下。 我有两个具有单向ManyToMany关系的实体:
public class Category implements Serializable {
@Id
@Column(name = "ct_id")
@SequenceGenerator(name = "category_ct_id_seq", sequenceName = "category_ct_id_seq", allocationSize = 1)
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "category_ct_id_seq")
private Long id;
@Column(name = "ct_name_key")
private String nameKey;
@ManyToMany
@JoinTable(name = "category_2_country",
joinColumns = @JoinColumn(name = "c2c_category_id"),
inverseJoinColumns = @JoinColumn(name = "c2c_country_id"))
private Set<Country> countries;
}
public class Country {
@Id
@SequenceGenerator(name = "country_c_id_seq", sequenceName = "country_c_id_seq", allocationSize = 1)
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "country_c_id_seq")
@Column(name = "c_id")
private Long id;
@Column(name = "c_name")
private String name;
@Column(name = "c_iso_2_alpha")
private String isoAlpha2Code;
我正在通过国家的ISO代码(实际上,所有类别,与所请求的国家/地区有关系)检索类别集合。为此,我写了一个规范:
public class CategorySpecification implements Specification<Category> {
Country matchCountry;
@Override
public Predicate toPredicate(Root<Category> root, CriteriaQuery<?> criteriaQuery, CriteriaBuilder builder) {
return builder.isMember(matchCountry, root.get("countries"));
}
}
这很好用。问题是我需要为每个国家的类别设置优先顺序。
传递表如下所示:
因此,当我检索给定国家/地区的类别集合时,我希望根据此sort_order
列对其进行排序。
相应的SQL查询看起来像这样:
SELECT *
FROM category
JOIN category_2_country ON category.ct_id = category_2_country.c2c_category_id
WHERE c2c_country_id = ?
ORDER BY sort_order;
但是我应该如何在我的JPA实体中创建呢?我应该如何将其保留回数据库,这个订单需要动态更改(例如从管理面板)?
EDITED: 数据库中与实体对应的表:
编辑2: 我已设法通过本机查询实现所需的行为,如下所示:
@Repository
public interface CategoryRepository extends JpaRepository<Category, Long>, JpaSpecificationExecutor<Category> {
@Query(value = "SELECT ct.*\n" +
"FROM category ct\n" +
" JOIN category_2_country c2c ON ct.ct_id = c2c.c2c_category_id\n" +
" JOIN country c ON c2c.c2c_country_id = c.c_id\n" +
"WHERE c.c_iso_2_alpha = :countryIso\n" +
"ORDER BY c2c.sort_order", nativeQuery = true)
List<Category> findCategoriesForCountryOrdered(@Param("countryIso") String countryIso);
}
但仍希望有更多的JPA / Hibernate方式来做这件事
答案 0 :(得分:1)
在使用规范时,您使用JpaRepository
和JpaSpecificationExecutor
。 JpaSpecificationExecutor
api为我们提供了一种方法findAll(Specification<T> spec, Sort sort)
。
使用Sort
类,您可以指定要对结果列表进行排序的属性(和方向)。
以下是文档:Sort
编辑:
在一些搜索之后 - 遗憾的是,没有将关联表映射到hibernate,你不能按sort_order
属性排序/排序。这与JPQL有关,它只适用于实体中的映射属性 - 如果您不映射它们,它就无法访问数据库中的表。
因此,您可以映射关联表并创建规范,这两个表连接这两个表并按sort_order
创建排序。