0

带有本地 lucene 的 Hibernate Search 6.0.1

我有一个搜索功能,用户可以在其中搜索两个字段的单词,其中一个是全文搜索,另一个是精确的关键字匹配。

Class A

@FullTextField(termVector = TermVector.YES, analyzer = "...", searchAnalyzer = "...")
private String text;

@KeywordField
private String keyword;

@IndexedEmbedded(includePaths = {"number"})
@OneToOne(mappedBy = "a", fetch = FetchType.LAZY)
private Stats stats;

我的搜索功能如下;

searchSession.search(A.class)
.where(f -> f.bool()
        .should(f.match().field("text").matching(query))
        .should(f.match().field("keyword").matching(query))
)
.sort(f -> f.field("stats.number").desc().missing().last())
.fetch(offset, limit);

我想搜索结果按数字排序的这两个字段。但是,我还想在搜索结果的顶部显示与关键字的完全匹配。(关键字是唯一的)

为了实现这一点,我应该怎么做?我是否需要将搜索功能分成两个不同的查询然后合并它们?还是有更好的做法?

4

1 回答 1

0

使用scoresorts 和 per-predicte 提升将给定谓词上的匹配项放在结果列表中更高的位置。然后使用字段排序对具有相同分数的结果进行排序。

这应该可以解决问题:

searchSession.search(A.class)
.where(f -> f.bool()
        .should(f.match().field("text").matching(query)
            .constantScore().boost(1.0f))
        .should(f.match().field("keyword").matching(query)
            .constantScore().boost(2.0f))
)
.sort(f -> f.score().then().field("stats.number").desc().missing().last())
.fetch(offset, limit);

也可以看看:

于 2021-03-11T07:22:13.560 回答