1

我有一个实体,我希望使用 Hibernate 搜索对其进行索引,以利用全文搜索功能。该实体有几个我需要过滤的字段。举个例子:

@Field(index = Index.TOKENIZED, store = Store.NO)
@Lob
private String description;

@Field(index = Index.UN_TOKENIZED, store = Store.NO)
@Enumerated(EnumType.STRING)
@NotNull
private Type type;

description字段是我要使用全文搜索的字段。Type我只想做一场普通的老比赛。Lucene 应该在进行全文搜索的基础上直接处理匹配,这对我来说有点不对劲,我应该使用类似的东西CriteriaBuilder来处理额外的过滤。但是,我找不到将两者结合起来的任何方法,我BooleanJunction在我的搜索算法中使用运算符must, matching, 和keyword在我需要直接匹配的字段上。

所以我的问题是,我做得对还是应该只使用 Lucene 进行全文搜索并以其他方式过滤其他属性?

非常感谢,芬巴尔

4

1 回答 1

1

@Finbarr,我的建议是为此使用 Hibernate Search。我建议按类型过滤您的结果,您应该使用 Hibernate Search FullTextFilter并在执行此查询之前启用通过“描述”搜索的 FullTextQuery 上的过滤器。如果文档不够,我可以为您发布一个示例,我经常使用这些过滤器并且它们工作得很好。

于 2011-08-26T22:09:24.727 回答