`

Solr 学习(5) —- Solr查询语法和参数

    博客分类:
  • Solr
 
阅读更多

1、查询地址

 

建立好solr的索引后,可以通过管理界面进行查询。http://127.0.0.1:8983/solr/admin/form.jsp

 

要尝试多个查询方法的话,可以进入full interface模式,并勾选debug选项,像下面这样

 

 


随便进行一个查询,如输入 hi ,通过返回的页面的debug项中,就可以看到solr进行查询的很多相关信息

 

 

<lst name="debug">
<str name="rawquerystring">hi</str>
<str name="querystring">hi</str>
<str name="parsedquery">text:hi</str>
<str name="parsedquery_toString">text:hi</str>
<lst name="explain">
<str name="1474002">
8.481748 = (MATCH) fieldWeight(text:hi in 207626), product of: 1.0 = tf(termFreq(text:hi)=1) 8.481748 = idf(docFreq=1336, maxDocs=2373631) 1.0 = fieldNorm(field=text, doc=207626)
</str>
<str name="556830">
8.481748 = (MATCH) fieldWeight(text:hi in 794169), product of: 1.0 = tf(termFreq(text:hi)=1) 8.481748 = idf(docFreq=1336, maxDocs=2373631) 1.0 = fieldNorm(field=text, doc=794169)
</str>
<str name="735197">
8.481748 = (MATCH) fieldWeight(text:hi in 901810), product of: 1.0 = tf(termFreq(text:hi)=1) 8.481748 = idf(docFreq=1336, maxDocs=2373631) 1.0 = fieldNorm(field=text, doc=901810)
</str>
<str name="2142779">
8.481748 = (MATCH) fieldWeight(text:hi in 1584789), product of: 1.0 = tf(termFreq(text:hi)=1) 8.481748 = idf(docFreq=1336, maxDocs=2373631) 1.0 = fieldNorm(field=text, doc=1584789)
</str>
<str name="182950">
8.481748 = (MATCH) fieldWeight(text:hi in 1862408), product of: 1.0 = tf(termFreq(text:hi)=1) 8.481748 = idf(docFreq=1336, maxDocs=2373631) 1.0 = fieldNorm(field=text, doc=1862408)
</str>
<str name="155112">
8.481748 = (MATCH) fieldWeight(text:hi in 1967709), product of: 1.0 = tf(termFreq(text:hi)=1) 8.481748 = idf(docFreq=1336, maxDocs=2373631) 1.0 = fieldNorm(field=text, doc=1967709)
</str>
<str name="2223440">
8.481748 = (MATCH) fieldWeight(text:hi in 2181479), product of: 1.0 = tf(termFreq(text:hi)=1) 8.481748 = idf(docFreq=1336, maxDocs=2373631) 1.0 = fieldNorm(field=text, doc=2181479)
</str>
<str name="2236992">
8.481748 = (MATCH) fieldWeight(text:hi in 2199957), product of: 1.0 = tf(termFreq(text:hi)=1) 8.481748 = idf(docFreq=1336, maxDocs=2373631) 1.0 = fieldNorm(field=text, doc=2199957)
</str>
<str name="2231513">
7.4968767 = (MATCH) fieldWeight(text:hi in 2179538), product of: 1.4142135 = tf(termFreq(text:hi)=2) 8.481748 = idf(docFreq=1336, maxDocs=2373631) 0.625 = fieldNorm(field=text, doc=2179538)
</str>
<str name="17885">
5.9975014 = (MATCH) fieldWeight(text:hi in 2009670), product of: 1.4142135 = tf(termFreq(text:hi)=2) 8.481748 = idf(docFreq=1336, maxDocs=2373631) 0.5 = fieldNorm(field=text, doc=2009670)
</str>
</lst>
<str name="QParser">LuceneQParser</str>
<lst name="timing">
<double name="time">8.0</double>
<lst name="prepare">
<double name="time">1.0</double>
<lst name="org.apache.solr.handler.component.QueryComponent">
<double name="time">1.0</double>
</lst>
<lst name="org.apache.solr.handler.component.FacetComponent">
<double name="time">0.0</double>
</lst>
<lst name="org.apache.solr.handler.component.MoreLikeThisComponent">
<double name="time">0.0</double>
</lst>
<lst name="org.apache.solr.handler.component.HighlightComponent">
<double name="time">0.0</double>
</lst>
<lst name="org.apache.solr.handler.component.StatsComponent">
<double name="time">0.0</double>
</lst>
<lst name="org.apache.solr.handler.component.DebugComponent">
<double name="time">0.0</double>
</lst>
</lst>
<lst name="process">
<double name="time">7.0</double>
<lst name="org.apache.solr.handler.component.QueryComponent">
<double name="time">5.0</double>
</lst>
<lst name="org.apache.solr.handler.component.FacetComponent">
<double name="time">0.0</double>
</lst>
<lst name="org.apache.solr.handler.component.MoreLikeThisComponent">
<double name="time">0.0</double>
</lst>
<lst name="org.apache.solr.handler.component.HighlightComponent">
<double name="time">0.0</double>
</lst>
<lst name="org.apache.solr.handler.component.StatsComponent">
<double name="time">0.0</double>
</lst>
<lst name="org.apache.solr.handler.component.DebugComponent">
<double name="time">2.0</double>
</lst>
</lst>
</lst>
</lst>
 

同时 在查询的头部信息中,也可以看到查询语法和参数是否被正确解析

 

 

<lst name="responseHeader">
<int name="status">0</int>
<int name="QTime">8</int>
<lst name="params">
<str name="explainOther"/>
<str name="fl">*,score</str>
<str name="debugQuery">on</str>
<str name="indent">on</str>
<str name="start">0</str>
<str name="q">hi</str>
<str name="hl.fl"/>
<str name="qt"/>
<str name="wt"/>
<str name="fq"/>
<str name="rows">10</str>
<str name="version">2.2</str>
</lst>
</lst>
 

 

具体命中的文档数可以在respose标签里找到,如下说明找到1328个包含查询词的文档

 

 

<result name="response" numFound="1328" start="0" maxScore="8.481748">
 

 

以上这些地方对分析解决查询中出现的问题都很有帮助

 

2、查询语法

 

 

solr的一些查询语法 

1.1. 首先假设我的数据里fields有:name, tel, address 预设的搜寻是name这个字段, 如果要搜寻的数据刚好就是 name 这个字段,就不需要指定搜寻字段名称. 

 

1.2. 查询规则: 

如欲查询特定字段(非预设字段),请在查询词前加上该字段名称加 “:” (不包含”号) 符号, 

例如: address:北京市海淀区上地软件园 tel:88xxxxx1 

1>. q代表query input 

 

2>. version代表solr版本(建议不要变动此变量) 

 

3>. start代表显示结果从哪一笔结果资料开始,预设为0代表第一笔, rows是说要显示几笔数据,预设为10笔 

(因为有时查询结果可能有几百笔,但不需要显示所有结果,所以预设是从第一笔开始到第十笔) 

所以若要显示第10到30笔就改为: 

http: //localhost:8080/solr/select/?indent=on&version=2.2&q=address:北京 市海淀区上地软件园+tel:88xxxxx1&version=2.2&start=10&rows= 20&indent=on 

(indent代表输出的xml要不要缩行.预设为开启 on) 

 

1.3. 另外,要限定输出结果的内容可用 “fl=” 加上你要的字段名称,如以下这个范例: 

http: //localhost:8080/solr/select/?indent=on&version=2.2&q=text:北京+ OR+text:亿度&start=0&rows=10&fl=name,address,tel 

在fl=之后加上了name,adress,tel 

所以结果会如下: 

 

 

 

3、查询参数

常用

  • q - 查询字符串,必须的。
  • fl - 指定返回那些字段内容,用逗号或空格分隔多个。
  • start - 返回第一条记录在完整找到结果中的偏移位置,0开始,一般分页用。
  • rows - 指定返回结果最多有多少条记录,配合start来实现分页。
  • sort - 排序,格式:sort=<field name>+<desc|asc>[,<field name>+<desc|asc>]… 。示例:(inStock desc, price asc)表示先 “inStock” 降序, 再 “price” 升序,默认是相关性降序。
  • wt - (writer type)指定输出格式,可以有 xml, json, php, phps, 后面 solr 1.3增加的,要用通知我们,因为默认没有打开。
  • fq - (filter query)过虑查询,作用:在q查询符合结果中同时是fq查询符合的,例如:q=mm&fq=date_time:[20081001 TO 20091031],找关键字mm,并且date_time是20081001到20091031之间的。官方文档:http://wiki.apache.org/solr/CommonQueryParameters

不常用

  • q.op - 覆盖schema.xml的defaultOperator(有空格时用"AND"还是用"OR"操作逻辑),一般默认指定
  • df - 默认的查询字段,一般默认指定
  • qt - (query type)指定那个类型来处理查询请求,一般不用指定,默认是standard。

其它

  • indent - 返回的结果是否缩进,默认关闭,用 indent=true|on 开启,一般调试json,php,phps,ruby输出才有必要用这个参数。
  • version - 查询语法的版本,建议不使用它,由服务器指定默认值。

[Solr的检索运算符]
 “:”
指定字段查指定值,如返回所有值*:*²
 “?”
²表示单个任意字符的通配
 “*” 表示多个任意字符的通配(不能在检索的项开始使用*或者?符号)
²
 “~”
²表示模糊检索,如检索拼写类似于”roam”的项这样写:roam~将找到形如foam和roams的单词;roam~0.8,检索返回相似度在0.8以上的记录。
²邻近检索,如检索相隔10个单词的”apache”和”jakarta”,”jakarta apache”~10
 “^”
²控制相关度检索,如检索jakarta apache,同时希望去让”jakarta”的相关度更加好,那么在其后加上”^”符号和增量值,即jakarta^4 apache
 布尔操作符AND、||
²
 
布尔操作符OR、²&&
 
布尔操作符NOT、!、-²(排除操作符不能单独与项使用构成查询)
 “+” 存在操作符,要求符号”+”后的项必须在文档相应的域中存在
²
 ( )
用于构成子查询²
² [] 包含范围检索,如检索某时间段记录,包含头尾,date:[200707 TO 200710]
 {}
²不包含范围检索,如检索某时间段记录,不包含头尾
date:{200707 TO 200710}
 " 转义操作符,特殊字符包括+ -
² && || ! ( ) { } [ ] ^ ” ~ * ? : "


  • 大小: 69 KB
分享到:
评论

相关推荐

    Apache Solr(solr-8.11.1.tgz)

    5. **docs 目录**:包含了Solr的文档,包括用户手册、API参考和教程,对于学习和调试Solr非常有用。 6. **server/solr 目录**:存储了配置集合的目录,每个集合都有自己的配置文件,如`schema.xml`用于定义字段和...

    solr(solr-9.0.0.tgz)

    Solr-9.0.0是该软件的最新版本,此版本可能包含了一些新的特性和改进,比如性能优化、新的查询语法、更强大的分析器等。 在Solr-9.0.0的压缩包中,通常会包含以下组件: 1. **bin** 文件夹:这个目录下有启动和...

    solr-8.1.1-src.tgz

    - Solr支持多种查询语法,包括标准查询解析器(QParser)和Lucene查询语法。 - 高级查询功能包括布尔运算符、短语匹配、通配符搜索、范围查询等。 5. **文档增删改查(CRUD)**: - 使用HTTP接口,通过XML、JSON或...

    apache-solr-ref-guide-7.4(官方英文-文字版本)

    4. **查询语法和解析**:详细说明了 Solr 支持的查询语法及其解析规则。 5. **JSON 请求 API**:介绍了如何使用 JSON 格式发送复杂的查询请求。 6. **JSON 面向 API**:提供了使用 JSON 格式进行面向 API 的查询...

    Apache Solr(solr-8.11.1.zip)

    5. **请求处理器**:Solr提供多种请求处理器,如标准请求处理器(StandardRequestHandler)用于处理默认的搜索请求,更新请求处理器(UpdateRequestHandler)处理索引更新,以及XML和JSON格式的数据导入处理器。...

    apache-solr-ref-guide-7.1.pdf

    “Query Syntax and Parsing”部分提供了关于查询语法和查询解析的详细信息。 “JSON Request API”部分讲述了使用JSON格式发送请求的API,这是Solr支持的几种请求格式之一。 “Faceting”部分介绍了如何在搜索...

    solr-7.4.0.zip

    Solr 7.4.0版本引入了许多新特性,比如增强的查询分析器,支持更丰富的JSON查询语法,以及性能上的优化。此外,它还支持动态字段和字段类型,方便处理各种数据结构。SolrCloud模式允许你构建高可用和可扩展的搜索...

    solr-7.6.0-windows

    7. 进行搜索查询,利用Solr提供的丰富查询语法和特性。 Solr 7.6.0版本是一个稳定且功能强大的版本,适用于各种规模的企业和项目。无论你是开发者、系统管理员还是数据分析师,都能从中受益,构建出高效、灵活的...

    solr-mongo-import-1.0和1.1

    2. 新特性:可能增加了新的配置选项或支持更多的MongoDB功能,比如支持新的数据类型或查询语法。 3. 兼容性增强:可能对新的MongoDB版本进行了适配,提升了与不同MongoDB版本的兼容性。 4. 错误修复:解决了1.0.0...

    apache-solr-ref-guide-6.6.html

    通过阅读和学习这份官方参考指南,开发者和运维人员可以更好地理解和利用Solr 6.6的特性,从而构建高效、稳定的全文检索系统。无论你是初学者还是经验丰富的专业人士,“apache-solr-ref-guide-6.6.html”都是你...

    solr-4-10.3.zip

    3. **查询与排序**: Solr提供了丰富的查询语法,包括布尔查询、短语查询、范围查询等,同时支持自定义排序规则,可以根据多个字段或复杂的评分函数进行排序。 4. **字段类型与分析**: Solr允许用户定义不同的字段...

    Solr权威指南-下卷.zip

    5. ** faceting(聚类)和群组查询**:理解如何使用Solr实现分类统计和群组查询,为用户提供更丰富的浏览体验。 6. **Solr与Spring集成**:介绍如何利用Spring的依赖注入和配置管理特性,简化Solr的集成和测试。 7...

    solr-8.10.0-src.tgz

    2. 新功能:可能引入了新的查询语法、分析器、过滤器或其他特性,以增强用户体验和功能多样性。 3. 修复错误:修复已知的 bug 和安全问题,确保系统的稳定性和安全性。 4. 对新技术的支持:随着技术的发展,Solr ...

    solr-3.6.0-src

    - **查询处理**:学习 Solr 如何解析查询语句,生成查询计划,并执行查询操作,包括评分机制和结果排序。 - **请求处理**:了解 Solr 请求处理器的工作流程,以及如何与 HTTP 交互,处理请求和返回响应。 - **...

    solr-6.2.0源码

    4. 高级搜索功能:Solr提供丰富的查询语法,如布尔逻辑、短语匹配、模糊匹配、字段限制等,以及自定义查询解析器和过滤器。 5. 自定义排序和评分:用户可以自定义文档排序规则和评分算法,以满足特定的业务需求。 6....

    solr6.5.1定时增量apache-solr-dataimportscheduler

    总的来说,Apache Solr6.5.1的定时增量数据导入特性通过`solr-dataimporthandler`和`solr-data-import-scheduler`这两个组件,实现了对数据源的自动化、智能化管理,极大地提高了数据检索的实时性和系统的响应速度。...

    最新版windows solr-8.8.2.zip

    7. **搜索功能**:Solr支持丰富的查询语法,如标准查询解析器、布尔操作符、通配符查询、短语匹配、近似搜索等,还能进行高亮显示、排序和 faceting(分类)。 8. **实时索引**:Solr支持实时索引,一旦数据被添加...

    solr启动报错-文件名目录名或卷标语法不正确-问题解决方法

    本文档记录了solr启动报错"文件名目录名或卷标语法不正确"问题的解决方法

    solr-4.10.3

    5. **Highlighting(高亮显示)**:4.10.3版本的Solr支持查询结果中的关键词高亮,提升用户体验,帮助用户快速定位到匹配的搜索内容。 6. **复制和更新策略**:Solr允许设置复制和更新策略,如实时索引更新,确保...

    Apache Solr(solr-7.7.3.zip)

    - **配置(Configuration)**: Solr 的配置文件位于 `conf` 目录下,包括 `schema.xml`(定义字段和字段类型)、`solrconfig.xml`(设置索引和查询行为)等,这些配置决定了 Solr 的行为。 **2. 安装与启动** 下载...

Global site tag (gtag.js) - Google Analytics