gpt4 book ai didi

hibernate 搜索排序

转载 作者:行者123 更新时间:2023-12-04 06:35:57 25 4
gpt4 key购买 nike

hibernate 搜索是根据相关性对结果进行排序,这很正常。
除此之外,如果两个文档的分数相同,则按其主键排序。

例如,

book1:id = 1,bookTitle =“通过示例进行 hibernate 搜索”。

book2:id = 2,bookTitle =“正在运行的 hibernate 搜索”

如果我正在查询以查找术语“hibernate 搜索”,我将具有以下顺序:book1然后book2

我想反转此顺序:book2然后book1。
这意味着反转主键顺序。
是否有可能在不实现自定义相似性的情况下做到这一点?同时保持相关性顺序。

最佳答案

是的,您需要创建一个Sort对象,该对象指定所需的排序,并在查询中进行设置。参见Section 5.1.3.3 of the Hibernate docs。然后,在 SortFields 列表中,传递SortField.FIELD_SCORE。 SortField的构造函数还允许您颠倒顺序。

org.hibernate.search.FullTextQuery query = s.createFullTextQuery( luceneQuery, MyEntity.class );
org.apache.lucene.search.Sort sort = new Sort(
SortField.FIELD_SCORE,
new SortField("id", SortField.STRING, true));
query.setSort(sort);
List results = query.list();

关于 hibernate 搜索排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30222490/

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