我的solr学习笔记--solr admin 页面 检索调试
前言
Solr/Lucene是一个全文检索引擎,全文引擎和SQL引擎所不同的是强调部分相关度高的内容返回,而不是所有内容返回,
所以部分内容包含在索引库中却无法命中是正常现象。
多数情况下我们建议优化分词器或者引擎其它部分达到预期检索效果。
-
按照如下步骤进入分词器调试界面
1、选择collection
2、选择analysis菜单
3、在索引框中输入要索引的文档
4、在检索框中输入要检索的词语
5、选择需要调试的字段,这里假设要将内容索引到title字段,并且在该字段上检索
6、点击分析按钮
7、在展示出来的原文分词结果(左侧)和关键词分词结果(右侧)中对比最下面一行,若右侧分词结果的所有词在左侧都能找到,那么在AND关系的检索时能够匹配;若部分能够找到,那么在OR关系的检索中能够匹配;若完全找不到,那么无法匹配。
索引一条记录,id=1,title=中华人民共和国来做调试
直接检索中华人民共和国
从上图看(图可放大),最终检索结果被解析成了”+text:中 +text:华 +text:人 +text:民 +text:共 +text:和 +text:国”,因为我们在q的输入框中没有输入检索字段,所以solr会检索默认字段”text”,而该字段不包含我们需要的信息,所以检索无结果。
输入正确的字段title后,可以成功检索出来
原文中华人民共和国分词后:中华、人民、共和国
搜索词中华解放军分词后:中华、解放军
部分匹配,我们也希望检索出来
从上图看(图可放大),最终检索结果被解析成了"+title:中 +title:华 +title:解放 +title:军",加号(+)标识逻辑与关系,相当于检索"title:中 AND title:华 AND title:解放 AND title:军",因此无法检索出来
修改默认逻辑关系
(q.op=OR)为OR后
,分此后的检索式加号没了,是逻辑或关系,因此能够成功检索出来。这里OR一定要大写。
这个默认检索关系可以通过修改schema.xml的defaultOperator进行配置
<solrQueryParser defaultOperator=”OR”/>
有时候用户会用空格输入多个关键字进行检索,如title:中华 人民 共和国
通过开启debugQuery参数,我们看到,最终检索结果被解析成了
+(+title:中 +title:华) +(+text:人 +text:民) +(+text:共 +text:和 +text:国)
中华是在title上检索的,后面的词都到text字段检索了
通过指定默认字段df为title,可以修正最终检索式,从上图看,修正后结果可以正常检索返回。
其它
以上是一些常见数据召回问题。
检索调优是搜索引擎使用中最复杂的过程,需要在长期实践中积累经验,同时需要了解数据情况,业务特点等多方面根据情况进行调整。
Solr web服务器管理界面用法
http://www.devnote.cn/article/38.html
相关文章
- ArcGIS 服务对象扩展(SOE)新手自学笔记(5):注册与调试
- 调试U-Boot笔记(六)
- 调试U-Boot笔记(五)
- 调试U-Boot笔记(八)
- 在VS2015中用C++创建DLL并用C#调用且同时实现对DLL的调试
- 51. 如何使用 Chrome 调试运行在手机上的 SAP UI5 Cordova 混合应用
- Fiori Launchpad Tile点击后跳转的调试技巧
- Angular页面里元素class的动态绑定的实现源代码调试
- Hybris ECP(Enterprise Commerce Platform)的调试
- SAP 电商云 Spartacus UI Angular Component 动态创建的单步调试
- 初级驱动调试笔记-总结
- Python学习53:调试
- SharePoint远程调试CSS
- 在 Visual Studio 中使用远程 MacOS 调试功能
- go语言笔记——append是内置的函数!!!new是一个函数!!!调试可以使用闭包,本质上是print调试,尼玛!
- go语言笔记——defer作用DB资源等free或实现调试
- pycharm远程调试配置
- FPGA-RAM核的使用及调试
- Android系统常用的调试工具