1、查询地址

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

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

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

  1. <lst name="debug">
  2. <str name="rawquerystring">hi</str>
  3. <str name="querystring">hi</str>
  4. <str name="parsedquery">text:hi</str>
  5. <str name="parsedquery_toString">text:hi</str>
  6. <lst name="explain">
  7. <str name="1474002">
  8. 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)
  9. </str>
  10. <str name="556830">
  11. 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)
  12. </str>
  13. <str name="735197">
  14. 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)
  15. </str>
  16. <str name="2142779">
  17. 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)
  18. </str>
  19. <str name="182950">
  20. 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)
  21. </str>
  22. <str name="155112">
  23. 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)
  24. </str>
  25. <str name="2223440">
  26. 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)
  27. </str>
  28. <str name="2236992">
  29. 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)
  30. </str>
  31. <str name="2231513">
  32. 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)
  33. </str>
  34. <str name="17885">
  35. 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)
  36. </str>
  37. </lst>
  38. <str name="QParser">LuceneQParser</str>
  39. <lst name="timing">
  40. <double name="time">8.0</double>
  41. <lst name="prepare">
  42. <double name="time">1.0</double>
  43. <lst name="org.apache.solr.handler.component.QueryComponent">
  44. <double name="time">1.0</double>
  45. </lst>
  46. <lst name="org.apache.solr.handler.component.FacetComponent">
  47. <double name="time">0.0</double>
  48. </lst>
  49. <lst name="org.apache.solr.handler.component.MoreLikeThisComponent">
  50. <double name="time">0.0</double>
  51. </lst>
  52. <lst name="org.apache.solr.handler.component.HighlightComponent">
  53. <double name="time">0.0</double>
  54. </lst>
  55. <lst name="org.apache.solr.handler.component.StatsComponent">
  56. <double name="time">0.0</double>
  57. </lst>
  58. <lst name="org.apache.solr.handler.component.DebugComponent">
  59. <double name="time">0.0</double>
  60. </lst>
  61. </lst>
  62. <lst name="process">
  63. <double name="time">7.0</double>
  64. <lst name="org.apache.solr.handler.component.QueryComponent">
  65. <double name="time">5.0</double>
  66. </lst>
  67. <lst name="org.apache.solr.handler.component.FacetComponent">
  68. <double name="time">0.0</double>
  69. </lst>
  70. <lst name="org.apache.solr.handler.component.MoreLikeThisComponent">
  71. <double name="time">0.0</double>
  72. </lst>
  73. <lst name="org.apache.solr.handler.component.HighlightComponent">
  74. <double name="time">0.0</double>
  75. </lst>
  76. <lst name="org.apache.solr.handler.component.StatsComponent">
  77. <double name="time">0.0</double>
  78. </lst>
  79. <lst name="org.apache.solr.handler.component.DebugComponent">
  80. <double name="time">2.0</double>
  81. </lst>
  82. </lst>
  83. </lst>
  84. </lst>

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

  1. <lst name="responseHeader">
  2. <int name="status">0</int>
  3. <int name="QTime">8</int>
  4. <lst name="params">
  5. <str name="explainOther"/>
  6. <str name="fl">*,score</str>
  7. <str name="debugQuery">on</str>
  8. <str name="indent">on</str>
  9. <str name="start">0</str>
  10. <str name="q">hi</str>
  11. <str name="hl.fl"/>
  12. <str name="qt"/>
  13. <str name="wt"/>
  14. <str name="fq"/>
  15. <str name="rows">10</str>
  16. <str name="version">2.2</str>
  17. </lst>
  18. </lst>

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

  1. <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}

 " 转义操作符,特殊字符包括+ -² && || ! ( ) { } [ ] ^ ” ~ * ? : "


Solr 学习(5) —- Solr查询语法和参数的更多相关文章

  1. lucene&solr学习——创建和查询索引(理论)

    1.Lucene基础 (1) 简介 Lucene是apache下的一个开放源代码的全文检索引擎工具包.提供完整的查询引擎和索引引擎:部分文本分析引擎. Lucene的目的是为软件开发人员提供一个简单易 ...

  2. Solr学习之四-Solr配置说明之二

    上一篇的配置说明主要是说明solrconfig.xml配置中的查询部分配置,在solr的功能中另外一个重要的功能是建索引,这是提供快速查询的核心. 按照Solr学习之一所述关于搜索引擎的原理中说明了建 ...

  3. Solr学习总结 Solr的安装与配置

    接着前一篇,这里总结下Solr的安装与配置 1.准备 1.安装Java8 和 Tomcat9 ,java和tomcat 的安装这里不再重复.需要注意的是这两个的版本兼容问题.貌似java8 不支持,t ...

  4. lucene&solr学习——创建和查询索引(代码篇)

    1. Lucene的下载 Lucene是开发全文检索功能的工具包,从官网下载Lucene4.10.3并解压. 官网:http://lucene.apache.org/ 版本:lucene7.7.0 ( ...

  5. Solr学习之三 solr配置说明之一

    严格来说,我这篇内容,主要是根据Solr in Action关于配置的说明,以及参考Solr的wiki写的算是读书笔记吧,所有的图片默认来自Solr in Action这本书. 这本书我觉得对学习So ...

  6. 我的solr学习笔记--solr admin 页面 检索调试

    前言 Solr/Lucene是一个全文检索引擎,全文引擎和SQL引擎所不同的是强调部分相关度高的内容返回,而不是所有内容返回,所以部分内容包含在索引库中却无法命中是正常现象.      多数情况下我们 ...

  7. lucene&solr学习——solr学习(二) Solr管理索引库

    1.什么是solrJ solrj是访问Solr服务的java客户端,提供索引和搜索的请求方法,SolrJ通常在嵌入在业务系统中,通过SolrJ的API接口操作Solr服务,如下图: 依赖jar包: 2 ...

  8. 02——Solr学习之Solr安装与配置(linux上的安装)

    借鉴博客:https://www.jianshu.com/p/1100f54fcbd8 https://www.cnblogs.com/jepson6669/p/9134652.html 1.准备一个 ...

  9. 03——Solr学习之Solr的使用(不会用)

    1.先放上次在linux搭建成功的solr管理UI界面 2.有个很蛋疼的问题我就要吐槽一下了 由于没接触过solr这玩意,在百度上一顿操作搜索怎么用,怎么导入数据,建索引库什么的,看了一大片别人的博客 ...

  10. Solr学习总结(四)Solr查询参数

    今天还是不会涉及到.Net和数据库操作,主要还是总结Solr 的查询参数,还是那句话,只有先明白了solr的基础内容和查询语法,后续学习solr 的C#和数据库操作,都是水到渠成的事.这里先列出sol ...

随机推荐

  1. tarjan—算法的神(一)

    本篇包含 tarjan 求强连通分量.边双连通分量.割点 部分, tarjan 求点双连通分量.桥(割边)在下一篇. 伟大的 Robert Tarjan 创造了众多被人们所熟知的算法及数据结构,最著名 ...

  2. Angular 18+ 高级教程 – 学以致用

    前言 读这么多原理,到底为了什么?真实项目中真的会用得到吗? 你正在疑惑 "知识的力量" 吗? 本篇会给一个非常非常好的案例,让你感悟 -- 知识如何用于实战. 记住,我的目的是让 ...

  3. ASP.NET Core – Configuration & Options

    前言 之前就写过 Asp.net core 学习笔记 ( Configuration 配置 ) 只是有点乱, 这篇作为整理版. 项目中会有许许多多的 Config 要设定. 比较好的管理方式是把它们放 ...

  4. Hugging Face NLP课程学习记录 - 0. 安装transformers库 & 1. Transformer 模型

    Hugging Face NLP课程学习记录 - 0. 安装transformers库 & 1. Transformer 模型 说明: 首次发表日期:2024-09-14 官网: https: ...

  5. C++ STL list容器——链表

    list容器 简介 链表是一种物理存储单元上非连续.非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的.链表由一系列节点组成,节点可以在运行时动态生成.每个节点包括两部分:一个是存储 ...

  6. 【赵渝强老师】Kubernetes平台中日志收集方案

    一.K8s整体日志收集方案 整体的日志收集方案,如下图所示: Filebeat是本地文件的日志数据采集器,可监控日志目录或特定日志文件(tail file),并将它们转发给Elasticsearch或 ...

  7. android启动时间测试

    需要对比基线测试的情况: Kernel log: adb shell dmesg Event log: adb shell logcat –b events Logcat log: adb shell ...

  8. 使用SourceTree管理仓库代码

    1.首先我们需要下载sourcetree,你可以去官网下载自己需要的版本. 2.安装完毕之后,我们需要获取ssh密钥与github关联上才能使用 按下面的操作开始执行.确定之后,会出现一个字符界面,输 ...

  9. 基于 Nginx 的大型互联网集群架构与实战方案

    1. Nginx 负载均衡基础配置 首先,搭建一个基础的 Nginx 负载均衡器,用于将流量分发到多个后端服务器上. 步骤 1.1:安装 Nginx 在每台要作为负载均衡器的服务器上,安装 Nginx ...

  10. 如何解决token过期问题 ?

    首先 token 过期会导致请求不到数据 , 就不能准确渲染页面 ,此时的错误配置项的token是过期的,只要更新了token 拿着原先的配置项重新请求数据即可 :但是如果更新token的时候请求错误 ...