gpt4 book ai didi

java - JPA 在多对多关系中按列排序

转载 作者:行者123 更新时间:2023-12-01 09:35:53 25 4
gpt4 key购买 nike

我的问题比第一眼所描述的要复杂一些。让我尝试解释一下。我有两个具有单向多对多关系的实体:

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"));

}
}

这工作得很好。问题是我需要为每个国家/地区的类别提供优先顺序。传递表如下所示: enter image description here因此,当我检索给定国家/地区的类别集合时,我希望根据此 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 实体中实现它?如果需要动态更改此顺序(例如从管理面板),我应该如何将其保留回数据库?

编辑:实体对应的数据库表:

国家的 Country

还有一个类别: enter image description here

编辑2:我已经成功地使用 native 查询实现了所需的行为,如下所示:

@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 方式来做这件事

最佳答案

当您使用规范时,您正在使用 JpaRepositoryJpaSpecificationExecutorJpaSpecificationExecutor api给了我们一个方法findAll(Specification<T> spec, Sort sort)

使用Sort类,您可以指定要按哪个属性(和方向)对结果列表进行排序。

这里是文档:Sort

编辑:经过一些搜索 - 不幸的是,如果没有将关联表映射到 hibernate 中,您无法按 sort_order 排序/排序属性(property)。这与 JPQL 相关,JPQL 只能作用于实体中的映射属性 - 如果不映射它们,它就无法访问数据库中的表。

因此,您可以映射关联表并创建规范,它将这两个表连接起来并按 sort_order 创建排序。 .

关于java - JPA 在多对多关系中按列排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38936247/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com