文档章节

Solr查询语法总结

Zero零_度
 Zero零_度
发布于 2015/08/23 09:42
字数 1039
阅读 261
收藏 7
点赞 0
评论 0

1、常用查询参数说明 
    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"操作逻辑),一般默认指定  “OR”    
    df - 默认的查询字段,一般默认指定 
    qt - (query type)指定那个类型来处理查询请求,一般不用指定,默认是standard。 
    其它 
    indent - 返回的结果是否缩进,默认关闭,用 indent=true|on 开启,一般调试json,php,phps,ruby输出才有必要用这个参数。 
    version - 查询语法的版本,建议不使用它,由服务器指定默认值。    
   
    solrconfig.xml的配置实例    
查询配置(以上参数项都可以配置到该配置文件)    
<requestHandler name="/select" class="solr.SearchHandler">    
     <lst name="defaults">    
       <str name="echoParams">explicit</str>    
       <int name="rows">10</int>

       <str name="defType">edismax</str>   //使用的是solr 扩展的查询解析器

      <str name="q.alt">*:*</str>  
      <str name="fq">sell_price:[1 TO *]</str>    
      <str name="hl">true</str>    
      <str name="hl.fl">room_name</str>    
           <str name="bf">sum(product(termfreq(room_status,"dzz"),1.2),1)</str> //额外的评分字段,这个是可以影响score的打分的    
      <str name="pf">  //要查询的字段    
            room_name house_code room_code zr_house_code hire_commissioner_name broker_name rating_address resblock_name district_name subway_station_name subway_line_name    
      </str>    
      <str name="qf"> //各自段分配的权重    
            room_name^5 house_code room_code zr_house_code  hire_commissioner_name broker_name rating_address resblock_name^2 district_name subway_station_name subway_line_name    
      </str>    
     </lst>    
</requestHandler>

另外schema.xml的defaultOperator参数是个很重要的参数,默认是“OR”,意思是要查询的关键词做完分词后的词做 “OR”连接,然后再做查询,而“AND”呢,要至少全包含要搜索的关键词才行。

2、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}    
     " 转义操作符,特殊字符包括+ -² && || ! ( ) { } [ ] ^ ” ~ * ? : "    
    
非空数据的查询 比如:fq=fcode:['' TO *] 查询fcode非空的数据

取反实例:fq=!fstate:1

3、facet查询

分类统计 facet 
    q=*:*&facet=true&facet.field=cat&facet.field=inStock  //按cat  inStock进行分类统计    
   
    q=ipod&facet=true&facet.query=price:[0 TO 100]&facet.query=price:[100 TO *]  //区间统计 价格在0-100 和100-无穷大的

--solr的分组查询(facet)  
http://IP:port/solr/room/select?rows=0&q=bizcircle_code:XXXXXX&facet=on    
&facet.field=resblock_id&facet.field=resblock_name&facet.limit=3   //同一个bizcircle_code下的 前三个resblock 各自的文档数量

facet使用的参考例子

引用别人的一篇博客:http://martin3000.iteye.com/blog/1330106

© 著作权归作者所有

共有 人打赏支持
Zero零_度
粉丝 66
博文 734
码字总数 252800
作品 0
程序员

暂无相关文章

Centos7重置Mysql 8.0.1 root 密码

问题产生背景: 安装完 最新版的 mysql8.0.1后忘记了密码,向重置root密码;找了网上好多资料都不尽相同,根据自己的问题总结如下: 第一步:修改配置文件免密码登录mysql vim /etc/my.cnf 1...

豆花饭烧土豆 ⋅ 55分钟前 ⋅ 0

熊掌号收录比例对于网站原创数据排名的影响[图]

从去年下半年开始,我在写博客了,因为我觉得业余写写博客也还是很不错的,但是从2017年下半年开始,百度已经推出了原创保护功能和熊掌号平台,为此,我也提交了不少以前的老数据,而这些历史...

原创小博客 ⋅ 今天 ⋅ 0

LVM讲解、磁盘故障小案例

LVM LVM就是动态卷管理,可以将多个硬盘和硬盘分区做成一个逻辑卷,并把这个逻辑卷作为一个整体来统一管理,动态对分区进行扩缩空间大小,安全快捷方便管理。 1.新建分区,更改类型为8e 即L...

蛋黄Yolks ⋅ 今天 ⋅ 0

Hadoop Yarn调度器的选择和使用

一、引言 Yarn在Hadoop的生态系统中担任了资源管理和任务调度的角色。在讨论其构造器之前先简单了解一下Yarn的架构。 上图是Yarn的基本架构,其中ResourceManager是整个架构的核心组件,它负...

p柯西 ⋅ 今天 ⋅ 0

uWSGI + Django @ Ubuntu

创建 Django App Project 创建后, 可以看到路径下有一个wsgi.py的问题 uWSGI运行 直接命令行运行 利用如下命令, 可直接访问 uwsgi --http :8080 --wsgi-file dj/wsgi.py 配置文件 & 运行 [u...

袁祾 ⋅ 今天 ⋅ 0

JVM堆的理解

在JVM中,我们经常提到的就是堆了,堆确实很重要,其实,除了堆之外,还有几个重要的模块,看下图: 大 多数情况下,我们并不需要关心JVM的底层,但是如果了解它的话,对于我们系统调优是非常...

不羁之后 ⋅ 昨天 ⋅ 0

推荐:并发情况下:Java HashMap 形成死循环的原因

在淘宝内网里看到同事发了贴说了一个CPU被100%的线上故障,并且这个事发生了很多次,原因是在Java语言在并发情况下使用HashMap造成Race Condition,从而导致死循环。这个事情我4、5年前也经历...

码代码的小司机 ⋅ 昨天 ⋅ 2

聊聊spring cloud gateway的RetryGatewayFilter

序 本文主要研究一下spring cloud gateway的RetryGatewayFilter GatewayAutoConfiguration spring-cloud-gateway-core-2.0.0.RC2-sources.jar!/org/springframework/cloud/gateway/config/G......

go4it ⋅ 昨天 ⋅ 0

创建新用户和授予MySQL中的权限教程

导读 MySQL是一个开源数据库管理软件,可帮助用户存储,组织和以后检索数据。 它有多种选项来授予特定用户在表和数据库中的细微的权限 - 本教程将简要介绍一些选项。 如何创建新用户 在MySQL...

问题终结者 ⋅ 昨天 ⋅ 0

android -------- 颜色的半透明效果配置

最近有朋友问我 Android 背景颜色的半透明效果配置,我网上看资料,总结了一下, 开发中也是常常遇到的,所以来写篇博客 常用的颜色值格式有: RGB ARGB RRGGBB AARRGGBB 这4种 透明度 透明度...

切切歆语 ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部