【发布时间】:2013-10-11 19:12:14
【问题描述】:
我从hibernate 文档构建了一个非常基本的hibernate 搜索。我很难限制结果,并且想就我做错的事情提出一些建议。
场景
假设我正在使用一个带有这样描述标题的实体
@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.
如何将结果限制为只返回一个匹配项?
【问题讨论】:
标签: hibernate lucene hibernate-search