我的问题比第一眼所描述的要复杂一点。让我试着解释一下。 我有两个实体单向多对多关系:JPA按多列对多列的顺序排列
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);
}
但还是希望有当你使用你正在使用JpaRepository
与JpaSpecificationExecutor
规格做这件事情
[This](http://stackoverflow.com/questions/5127129/mapping-many-to-many-association-table-with-extra-columns)可能会有所帮助。 –
我之前看到过这个线程,但仍然希望比仅仅因为优先级列重构所有实体更简单的解决方案 – DruidKuma