我正在使用Java EE,Hibernate Search,JPA和JSF编写Web应用程序。
我一遍又一遍地阅读hibernate搜索文档,但我无法正常工作。
我有一个包含多个类别的数据库。我为足球俱乐部做了一个例子。
我有德国类别,其中有德甲联赛,德甲联赛等。 我还有一个名为ChampionsLeague,EuroLeague和其他一些代表不同国家的联盟。
如果我搜索“Deutschland”,Hibernate Search会为我提供所有在德国比赛的足球俱乐部的正确列表。一些足球俱乐部参加了ChampionsLeague和Euroleage。左侧导航栏中的Faceting为我提供了德国俱乐部参与的类别。此外,它还显示了正确的facetedCount。
问题是,如果我点击其中一个类别,Hibernate Search会向我显示此类别中的所有俱乐部,而不仅仅是我在初次搜索时搜索过的德语俱乐部。
有人能告诉我如何解决这个问题吗?
这是我的代码: SearchBean:
public void startKeywordSearch(){
fullTextEntityManager = org.hibernate.search.jpa.Search.getFullTextEntityManager(em);
qb = fullTextEntityManager.getSearchFactory().buildQueryBuilder().forEntity(Company.class).get();
query = qb
.keyword()
.fuzzy().withEditDistanceUpTo(1).withPrefixLength(0)
.onFields("companyName", "companyShortDescription", "companyLongDescription", "categoryList.categoryName", "and so on")
.matching(keyword)
.createQuery();
categoryNameFacetingRequest = qb.facet()
.name("categoryNameFacet")
.onField("categoryList.categoryName_forFaceting")
.discrete()
.orderedBy(FacetSortOrder.COUNT_DESC)
.includeZeroCounts(false)
.maxFacetCount(100)
.createFacetingRequest();
persistenceQuery = fullTextEntityManager.createFullTextQuery(query, Company.class);
facetManager = fullTextEntityManager.createFullTextQuery(query, Company.class).getFacetManager();
facetManager.enableFaceting(categoryNameFacetingRequest);
result = persistenceQuery.getResultList();
facetResults = facetManager.getFacets("categoryNameFacet");
searchCount = result.size();
这是我的addFacet方法代码:
public void addFacet(Facet facet) {
fullTextEntityManager = org.hibernate.search.jpa.Search.getFullTextEntityManager(em);
Query luceneQuery = facet.getFacetQuery();
persistenceQuery = fullTextEntityManager.createFullTextQuery(luceneQuery, Company.class);
facetManager.enableFaceting(categoryNameFacetingRequest);
result = persistenceQuery.getResultList();
facetResults = facetManager.getFacets("categoryNameFacet");
FacetSelection facetSelection = facetManager.getFacetGroup("categoryNameFacet");
facetSelection.selectFacets(facet);
result = persistenceQuery.getResultList();
这就是生成链接的代码:
<div>
<h:form id="facetForm">
<ul>
<ui:repeat value="#{searchBean.facetResults}" var="facet">
<li><h:commandLink value="#{facet.value}" action="#{searchBean.addFacet(facet)}">
<f:ajax render="@all" />
</h:commandLink> (#{facet.count})</li>
</ui:repeat>
</ul>
</h:form>
</div>
答案 0 :(得分:0)
不确定您在何处呼叫addFacet
,但看起来您只是运行facet#getFacetQuery
提供的查询。这不会奏效。 facet查询应该应用于现有查询之上。通过布尔查询或通过FacetSelection
(作用于原始查询之上)。该文档有一个例子:
// create a fulltext query
Query luceneQuery = builder.all().createQuery(); // match all query
FullTextQuery fullTextQuery = fullTextSession.createFullTextQuery( luceneQuery, clazz );
// retrieve facet manager and apply faceting request
FacetManager facetManager = fullTextQuery.getFacetManager();
facetManager.enableFaceting( priceFacetingRequest );
// get the list of Cd
List<Cd> cds = fullTextQuery.list();
assertTrue(cds.size() == 10);
// retrieve the faceting results
List<Facet> facets = facetManager.getFacets( "priceFaceting" );
assertTrue(facets.get(0).getCount() == 2)
// apply first facet as additional search criteria
FacetSelection facetSelection = facetManager.getFacetGroup( "priceFaceting" );
facetSelection.selectFacets( facets.get( 0 ) );
// re-execute the query
cds = fullTextQuery.list();
assertTrue(cds.size() == 2);
请参阅http://docs.jboss.org/hibernate/search/5.3/reference/en-US/html_single/#_restricting_query_results