共计 2155 个字符,预计需要花费 6 分钟才能阅读完成。
本篇内容主要讲解“solr 分词查询怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让丸趣 TV 小编来带大家学习“solr 分词查询怎么使用”吧!
1 实验 1.1 准备
分词字段:/CaseInfo/ 案 /@DocContent
分词器:IKAnalyzer2012
测试关键字:抢劫黄金
返回字段:/CaseInfo/ 案 /@DocContent
分别插入 3 条数据,向 DocContent 插入不同的值
1.2 测试
1、 查询条件:*:*
查询结果如下:
2、查询条件:\/CaseInfo/ 案 /@DocContent: 抢劫黄金
查询结果如下:
3、查询条件:\/CaseInfo/ 案 /@DocContent: 抢劫黄金
注意:抢劫黄金加了引号。
查询结果如下:
4、查询条件:\/CaseInfo/ 案 /@DocContent: 抢劫 AND \/CaseInfo/ 案 /@DocContent: 黄金
查询结果如下:
5、查询条件:\/CaseInfo/ 案 /@DocContent: 抢劫 OR \/CaseInfo/ 案 /@DocContent: 黄金
查询结果如下:
6、查询条件:\/CaseInfo/ 案 /@DocContent: 抢劫 黄金
注意:抢劫与黄金中间添加空格
查询结果为空:
1.3 结果分析
由于查询结果与 solr 解析的查询语句有关,勾选界面左下角的 debugQuery,可以得到对应 parsedquery_toString 值,如下表:
根据上表可以得到下面的分析结果
1.3.1 *:*
查询语句表示查询全部数据。
1.3.2 \/CaseInfo/ 案 /@DocContent: 抢劫黄金
表示查询的 DocContent 字段经过分词后,必须包含“抢劫”且包含“黄金”。parsedquery_toString 值中“+”表示存在操作符,要求符号“+”后面的项必须在字段中存在。经过第一张表分词结果,两条数据满足要求。
a) 抢劫黄金
b) 黄金不要抢劫
1.3.3 \/CaseInfo/ 案 /@DocContent: 抢劫黄金
加了双引号表示完全匹配,表示查询的 DocContent 字段经过分词后,必须包含“抢劫黄金”,经过第一张表分词结果,一条数据满足要求。
a) 抢劫黄金
1.3.4 \/CaseInfo/ 案 /@DocContent: 抢劫 AND \/CaseInfo/ 案 /@DocContent: 黄金
AND 表示既满足左条件又满足右条件。DocContent 字段经过分词后,既要包含“抢劫”且包含“黄金”。两条数据满足要求。
a) 抢劫黄金
b) 黄金不要抢劫
1.3.5 \/CaseInfo/ 案 /@DocContent: 抢劫 OR \/CaseInfo/ 案 /@DocContent: 黄金
OR 表示或者,满足一个条件就可以。DocContent 字段经过分词后,包含“抢劫”或包含“黄金”。三条数据满足要求。三条结果:
a) 抢劫黄金
b) 黄金不要抢劫
c) 太阳黄太阳金抢劫
1.3.6 \/CaseInfo/ 案 /@DocContent: 抢劫 黄金
这里查询结果为空。分析 parsedquery_toString 值:
+/CaseInfo/ 案 /@DocContent: 抢劫 +(+text: 黄 +text: 金)
表示 DocContent 字段分词后必须包含“抢劫”,并且 text 字段必须包含“黄”与“金”才能满足条件。由于我们没有想 text 字段赋值,所以下旬结果为空。为什么会有 text 字段的呢?
schema.xml 中
!– defaultSearchField text /defaultSearchField —
在 solrconfig.xml 中
requestHandler name= /select >
!– default values for query parameters can be specified, these
will be overridden by parameters in the request
—
lst name= defaults
str name= echoParams explicit /str
int name= rows 10 /int
str name= df text /str
/lst
/requestHandler
schema.xml 中 defaultSearchField 与 solrconfig.xml 中 df 属性都是默认搜索字段的意思(注意:defaultSearchField 默认是被注释的),优先级是 solrconfig.xml 的 df 高于 schema.xml 中的 defaultSearchField。
设置默认字段的效果,搜索条件为 \/CaseInfo/ 案 /@DocContent: 抢劫 黄金,中间的空格相当于 AND,因此搜索条件等价于 \/CaseInfo/ 案 /@DocContent: 抢劫 AND text: 黄金,所以不会搜索岛结果。
解决方法:
方法 1:可以把条件变为 \/CaseInfo/ 案 /@DocContent:(抢劫 黄金)。
方法 2:搜索条件不变,查询时 URL 加上 df 字段值为 /CaseInfo/ 案 /@DocContent 即可。
到此,相信大家对“solr 分词查询怎么使用”有了更深的了解,不妨来实际操作一番吧!这里是丸趣 TV 网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!