solr 自定义 dismax查询方式
来源:互联网 发布:360网络修复工具下载 编辑:程序博客网 时间:2024/05/18 01:46
1、在solrconfig.xml中增加
- <queryParser name="imdismax"
- class="com.szhtp.search.parse.IMDisMaxQParserPlugin" />
- <requestHandler name="imdismax" class="solr.SearchHandler">
- <lst name="defaults">
- <str name="defType">imdismax</str>
- <!-- 查询关键字和设置权重 -->
- <str name="qf">keywords^3 question^2 answer^0.4</str>
- <str name="pf">keywords^3 question^2 answer^0.4</str>
- <str name="mm">2<-1 5<-2 6<90%</str>
- <!-- 输出时显示那些字段 -->
- <str name="fl">id,answer,score</str>
- <!-- 设置PhraseSlop的坡度 -->
- <int name="ps">100</int>
- <str name="hl.fl">answer</str>
- <!-- 默认查询语句用于容错处理 -->
- <str name="q.alt">*:*</str>
- <!-- 每个snippet返回的最大字符数。默认是100.如果为0,那么该字段不会被fragmented且整个字段的值会被返回。大字段时不会这么做。
- 这里的answer=<str name="hl.fl">answer</str>
- -->
- <str name="f.answer.hl.fragsize">50</str>
- <!-- instructs Solr to return the field itself if no query terms are
- found -->
- <!-- 如果没有生成snippet(没有terms 匹配),那么使用另一个字段值作为返回 -->
- <str name="f.answer.hl.alternateField">answer</str>
- <!-- 这个是solr制定fragment算法的扩展点。gap是默认值。
- regex是另一种选项,这种选项指明highlight的边界由一个正则表达式确定。
- 这是一种非典型的高级选项。为了知道默认设置和fragmenters (and formatters)是如何配置的,
- 可以看看solrconfig.xml中的highlight段 -->
- <str name="f.answer.hl.fragmenter">regex</str>
- <str name="tie">0.1</str>
- </lst>
- </requestHandler>
2、创建类IMDisMaxQParserPlugin.java
- public class IMDisMaxQParserPlugin extends QParserPlugin
- {
- public static String NAME = "imdismax";
- public void init(NamedList args) {
- }
- public QParser createParser(String qstr, SolrParams localParams, SolrParams params, SolrQueryRequest req) {
- return new IMDisMaxQParser(qstr, localParams, params, req);
- }
- }
3、创建类IMDisMaxQParser.java 可以在里面增加中文分词
- public class IMDisMaxQParser extends DisMaxQParser
- {
- public IMDisMaxQParser(String qstr, SolrParams localParams,
- SolrParams params, SolrQueryRequest req)
- {
- super(qstr, localParams, params, req);
- if (null == this.qstr)
- {
- return;
- }
- Analyzer analyzer = req.getSchema().getQueryAnalyzer();
- if (null == analyzer)
- {
- return;
- }
- StringBuilder norm = new StringBuilder();
- try
- {
- //对question分词
- TokenStream tokens = analyzer.reusableTokenStream("question",
- new StringReader(this.qstr));
- tokens.reset();
- Token token = tokens.next();
- while (token != null)
- {
- norm.append(
- new String(token.termBuffer(), 0, token.termLength()))
- .append(" ");
- token = tokens.next();
- }
- }
- catch (Exception ex)
- {
- }
- if (norm.length() > 0)
- this.qstr = norm.toString();
- }
- }
0 0
- solr 自定义 dismax查询方式
- solr 自定义 dismax查询方式
- Solr Dismax查询解析器-深入分析
- solr dismax
- Solr的查询解析器DisMax Query Parser
- Solr的查询解析器The Extended DisMax Query Parser
- Solr DisMax 分析
- Solr Dismax示例
- DisMax查询解析器
- solr dismax与edismax的参数列表
- solr:关于dismax的使用情况
- solr dismax与edismax的参数列表
- Dismax
- solr 的edismax与dismax比较与分析
- solr 的edismax与dismax比较与分析
- solr 的edismax与dismax比较与分析
- solr 自定义QueryParser 用户查询解析方案
- solr查询
- js按钮闪动效果
- protocol buffer Developer Guide-Language Guide
- solr4.7中文分词器(ik-analyzer)配置
- adt-bundle 20140702各平台下载地址
- 为UITextView添加与UITextField一样的边框——UITextField默认边框
- solr 自定义 dismax查询方式
- Solr4.7从数据库导数据
- 第三章作业3.22
- 【Nginx】Nginx配置优化
- Android开发的ANR异常
- ssh免密码登陆
- Object-C之块枚举的使用
- 基本、数组、引用类型的参数传递
- ArrayList、Vector和LinkedList区别