gpt4 book ai didi

jpa - Spring 数据按给定键内的映射值排序

转载 作者:行者123 更新时间:2023-12-04 13:50:09 27 4
gpt4 key购买 nike

我想按值对 Map 进行排序。例如,我有一个 Person 类,它有一个 details 的 map ,这些 map 存储在键值 Map<String, String> 的 map 中。 .

我正在使用带有 hibernate5 的 springboot。这是映射。

public class Person implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@DocumentId
@Column(name = "personid")
private Integer id;

@Column(name = "name")
private String name;

// this is a collection of person details
@ElementCollection()
@MapKeyColumn(name = "detailkey")
@Column(name = "detailvalue")
@CollectionTable(name = "details", joinColumns = @JoinColumn(name = "personid"))
Map<String, String> details = new HashMap<>();

//getter and setters omitted

到目前为止,我能够通过一些特定的 detailskey 和特定的 detail 值来检索一个人。因此,例如,数据库中的人员表将 eyecolor 作为详细属性,并且作为值可以具有“green”、“blue”、“<强>棕色 ”。请注意,这不是真实示例,只是为了清楚起见。

例如,我可以在 Controller 中获取人员列表并按姓名对他们进行排序

Sort sort = new Sort(Sort.Direction.ASC, "name");

反方向

Sort sort = new Sort(Sort.Direction.DESC, "name");
Pageable pageable = new PageRequest(1, 10, sort);
pageResult = personRepository.findAll(
"eyecolor", "green", pageable
);

这个将返回“eyecolor”为绿色的人员列表。到目前为止一切顺利,这按预期工作。现在我想定义一个关于细节值的排序。

例如,我想获得一个按眼睛颜色排序的人的列表。所以首先我应该让拥有“blue”、“brown”、“green”的人。

在这种情况下如何指定排序?

在标准 SQL 中,它会是这样的:

SELECT p.* from persons p LEFT JOIN details d ON p.personid = d.personid AND p.detailkey='eyercolor' ORDER BY p.detailvalue ASC;

最佳答案

以下查询对我有用:

SELECT p FROM Person p JOIN p.details d WHERE KEY(d) = 'eyecolor' ORDER BY d

(请注意,ORDER BY VALUE(d) 会失败,因为 VALUE(d) 的行为似乎仍如此处所述:JPA's Map<KEY, VALUE> query by JPQL failed)

现在,我不是特别精通 Spring Data,但我想您应该能够将上述查询(没有 ORDER BY 部分)与 @Query 注释在您的 PersonRepository.findAll 方法上(我假设这是一个自定义方法)并使用 JpaSort.unsafe("d") 提供排序。

关于jpa - Spring 数据按给定键内的映射值排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43573534/

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