zoukankan      html  css  js  c++  java
  • 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());
     }
  • 相关阅读:
    Python rindex()方法
    Python rfind()方法
    Python replace()方法
    服务器技术综述(三)
    服务器技术综述(二)
    服务器技术综述(一)
    TensorRT-优化-原理
    TensorRT-安装-使用
    TensorRT 加速性能分析
    GPU加速:宽深度推理
  • 原文地址:https://www.cnblogs.com/likehua/p/2002014.html
Copyright © 2011-2022 走看看