0

我从休眠文档构建了一个非常基本的休眠搜索。我很难限制结果,并且想就我做错的事情提出一些建议。

设想

假设我正在使用一个具有这样描述标题的实体

@Field(index=Index.YES, analyze=Analyze.YES, store=Store.NO)
private String name;

将以下数据添加到索引中

1. Dell Laptop
2. Dell Desktop
3. HP Desktop

我的搜索看起来像这样,

    FullTextSession fullTextSession = Search.getFullTextSession(sessionManager.getSession());
    QueryBuilder queryBuilder = fullTextSession.getSearchFactory().buildQueryBuilder().forEntity(Computer.class).get();
    Query luceneQuery = queryBuilder.keyword().onFields("name").matching(keyword).createQuery();

    org.hibernate.search.FullTextQuery fullTextQuery = fullTextSession.createFullTextQuery(luceneQuery, Computer.class);

现在,当您使用以下内容进行关键字搜索时,一切正常,

Dell returns Dell Laptop, Dell Desktop
Desktop returns Dell, HP

但是,当您进行这样的搜索时,它不会正确限制结果

Dell Desktop returns Dell Laptop, Dell Desktop, HP Desktop. 

我如何将结果限制为仅返回一个匹配项?

4

1 回答 1

1

“戴尔台式机”可能不是一个单一的术语。您应该尝试将其作为短语进行搜索。

Query luceneQuery = queryBuilder.phrase().onField("name").sentence(keyword).createQuery();
org.hibernate.search.FullTextQuery fullTextQuery = fullTextSession.createFullTextQuery(luceneQuery, Computer.class);

您还可以使用示例 5.2中的 Hibernate Search 文档第 5 章中记录的查询解析器

于 2013-10-11T20:53:03.133 回答