Solr解析器通用查询参数

网友投稿 631 2022-05-29

本文主要介绍下Solr解析器中通用的查询参数。这些参数能够在标准查询解析器、DisMax查询解析器及eDisMax查询解析器中通用。

下表总结了Solr通用的查询参数,支持标准的、DisMax、eDisMax查询请求。

接下来的章节将详细描述各个参数。

defType

参数defType指定Solr执行主查询时使用的查询解析器。比如:defType=dismax。

如果没有指定defType,将默认使用标准个查询解析器。

sort

参数sort指定查询结果升序或降序。这个参数可以作用于数字或字母内容。可以使用全消息或全大写。(比如,全是asc或ASC)。

Solr可以根据文档分值或其他被索引或使用DocValues(即,在schema.xml文件中使用multiValued="false"和docValues="true"或者indexed="true"的字段,如果没有启用DocValues,将使用检索数据)的单值字段值来进行排序。提供:

没有进行标记(即,字段没有analyzer,并且内容被解析进标记,致使排序不一致),或

使用分析器analyzer(比如KeywordTokenizer)且只产生一个检索词。

如果你向对一个需要进行标记便于检索的字段排序,可以在schema.xml文件中使用指定复制字段。然后就可以查询该字段,在克隆字段上排序。

下面的表格将说明如果设置各种参数来对Solr响应进行排序:

关于排序参数:

排序必须包含一个字段名(或打分),之后跟一个空白字符(在URL字符串中使用+或%20),之后跟排序方向(asc或desc)。

多种排序规则可以使用逗号隔开,使用这样的语法:sort=+,+],...

如果有多个排序条件,只有在第一个排序结果并列,第二个才生效。如果有第三个从句,只有当第一个和第二个都并列相同时,才生效。依次类推。

start

该参数指定Solr查询响应展示内容的偏移量。默认值是0.换句话说,默认情况下,Solr返回的结果没有偏移,从头开始。设置一个值,比如3,Solr将跳过前面 几条数据,从指定偏移位置开始返回。你可以使用这种方式来分页。比如,如果参数rows设置为10,可以通过设置start为0来连续返回几页数据,然后使用相同的查询参数,设置start为10,再次查询,然后设置20.

rows

可以使用参数rows来进行分页查询。这个参数指定了一次查询最大返回文档的数目。默认值是10.就是说,默认一次查询返回10个文档数据。

fq

参数fq可以定义一个限制返回文档父集,不影响评分。通过指定参数fq将缓存主查询,用来提高复杂查询速度。当之后使用相同的过滤器,将会命中缓存,缓存中的结果立即返回。

使用参数fq时,需要注意:

参数fq可以在一个查询中指定多次。只有每个参数实例的交集才能返回。在下面的例子中,只有popularity大于10且section是0的才能返回。fq=popularity:[10 TO *]&fq=section:0

过滤查询可以包含复杂的布尔查询。上面的例子也可以使用两个从句一个fq实现:fq=+popularity:[10 TO *] +section:0。

每个过滤查询的文档集都是独立缓存的。一次,关于签名的例子:使用一个fq两个从句,和使用两个分开的fq将不想同(了解调整高速缓存大小和确保过滤缓存,看配置Solr实例)。

对所有参数:在URL中特殊字符需要进行转移为十六进制。在线工具http://meyerweb.com/eric/tools/dencoder/可以提供这种转码。

fl

参数fl限制响应信息中包含的字段列表。该字段需要在索引时被存储。

Solr解析器通用的查询参数

字段列表可以通过空格或逗号分割。字符串”score”可以被用来指明特定查询的每个文档的分数作为字段返回。通配符”*”表示文档的所有字段。可以添加伪字段、函数、transformers作为字段返回。

下表是如果使用fl的基础示例:

Function Values

函数可以为结果中每一个文档计算结果,并返回伪字段:fl=id,title,product(price,popularity)。

Document Transformers

Document Transformers可以用来修改查询结果中的每一个文件的返回信息:fl=id,title,[explain]。

Field Name Aliases

可以指定字段、函数、transformer的显示名,比如:fl=id,sales_price:price,secret_sauce:prod(price,popularity),why_score:[explain style=nl],

"response":{"numFound":2,"start":0,"docs":[ { "id":"6H500F0", "secret_sauce":2100.0, "sales_price":350.0, "why_score":{ "match":true, "value":1.052226, "description":"weight(features:cache in 2) [DefaultSimilarity], result of:", "details":[{ ...

1

2

3

4

5

6

7

8

9

10

11

debug

参数debug可以指定多次,并支持以下参数:

debug=query: 至返回查询的调试信息

debug=timing: 返回查询执行时间的调试信息

debug=results: 返回结果分值的调试信息

debug=all: 返回所有的调试信息(也可以使用debug=true)

为了向后兼容,debugQuery=true可以使用debug=all替代。

默认查询不包括调试信息。

explainOther

参数explainOther指定Lucene查询来标记文档集。如果非空,本次查询将返回调试信息,以及主查询(指定q参数)查询文档集的解释信息。比如:q=supervillians&debugQuery=on&explainOther=id:juggernaut。

上面的查询允许你检查最佳匹配的分值解释信息,可以与id:juggernaut进行比较,可以知道为什么不是你期望的排名。

默认参数为空,没有额外解释信息返回。

timeAllowed

This parameter specifies the amount of time, in milliseconds, allowed for a search to complete. If this time expires before the search is complete, any partial results will be returned.

此参数指定允许搜索完成的时间,以毫秒为单位。如果处理超时,只返回部分信息。

omitHeader

This parameter may be set to either true or false.

该参数可以设置为true或false。

如果设置为true,返回结果中不包含header数据。header数据包括请求信息,比如请求完成时间。默认是false。

wt

指定用于格式化响应结果的请求writer。详细信息查看Response Writers。

cache=false

Solr默认缓存所有的查询、过滤查询结果。为了禁用缓存,设置参数cache=false。

还可以使用cost选项来控制非缓存的过滤查询。这允许你能够指定低耗非缓存过滤,而不是高耗非缓存过滤器。

对于高耗过滤器,如果cache=false,cost>=100,查询实现了PostFilter,在匹配主查询和其他过滤查询之后,一个收集器将被请求来进行查询和过滤文档。可以有多个后置过滤器,可以根据cost配置。

比如:

// normal function range query used as a filter, all matching documents // generated up front and cached fq={!frange l=10 u=100}mul(popularity,price) // function range query run in parallel with the main query like a traditional // lucene filter fq={!frange l=10 u=100 cache=false}mul(popularity,price) // function range query checked after each document that already matches the query // and all other filters. Good for really expensive function queries. fq={!frange l=10 u=100 cache=false cost=100}mul(popularity,price)

1

2

3

4

5

6

7

8

9

10

11

logParamsList

默认情况下,Solr日志记录所有请求参数。从4.7版本开始,可以设置参数来限制哪些参数被记录。这有助于记录你认为比较重要的参数。比如,你可以定义:logParamsList=q,fq。只有q和fq参数会被记录。

如果不希望记录任何参数,你可以给参数logParamsList赋空值(比如:logParamsList=)。

这个参数可以应用与所有的Solr请求,不只查询请求。

Lucene/Solr

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:世界上没有技术驱动型公司
下一篇:《Hadoop权威指南:大数据的存储与分析》—4.3 YARN中的调度
相关文章