lucene3.0中使用MultiFieldQueryParser多字段查找
使用Lucene做全文检索,一般我们经常会在多个字段(域)中查找,而不一定关心在那个字段中包含需要查找的值.比如在搜索框中输入:亲亲宝宝 软件开发,只要标题、内容、作者等包含“亲亲宝宝 软件开发”都是我们要查找的结果。Lucene中MultiFieldQueryParser正好给我们提供多字段查找带来方便.
MultiFieldQueryParser multiParser=
new MultiFieldQueryParser(Version.LUCENE_CURRENT
,new String[]{"title","content","author"},analyzer);
multiParser.setPhraseSlop(3);
//设置短语搜索的坡度为3,默认为0
multiParser.setDefaultOperator(QueryParser.Operator.AND);
//设置以空格分开的短语是并的关系,默认为或的关系;
Query query=multiParser.parse(str);
但是我使用的lucene3.0的MultiFieldQueryParser有点问题,就是setPhraseSlop后不能产生作用,在源代码的136行修改0为 this.getPhraseSlop()即可.
protected Query getFieldQuery(String field, String queryText) throws ParseException {
return getFieldQuery(field, queryText, this.getPhraseSlop());
}
标签:
lucene
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架