solr 查询

solr 查询参数说明  
常用 
q - 查询字符串,必须的。 
fl - 指定返回那些字段内容,用逗号或空格分隔多个。 
start - 返回第一条记录在完整找到结果中的偏移位置,0开始,一般分页用。

rows - 指定返回结果最多有多少条记录,配合start来实现分页。

sort - 排序,格式:sort=<field name>+<desc|asc>[,<field name>+<desc|asc>]… 。

示例:(inStock desc, price asc)表示先 “inStock” 降序, 再 “price” 升序,默认是相关性降序。 注:排序字段 只能针对数值型如:int,dobuble等…

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之间的。

不常用 
q.op - 覆盖schema.xml的defaultOperator(有空格时用"AND"还是用"OR"操作逻辑),一般默认指定 
df - 默认的查询字段,一般默认指定  
qt - (query type)指定那个类型来处理查询请求,一般不用指定,默认是standard。  
indent - 返回的结果是否缩进,默认关闭,用 indent=true|on 开启,一般调试json,php,phps,ruby输出才有必要用这个参数。 ? 
version - 查询语法的版本,建议不使用它,由服务器指定默认值。  
Solr的检索运算符 
1. “:” 指定字段查指定值,如返回所有值*:* 2. “?” 表示单个任意字符的通配 
3. “*” 表示多个任意字符的通配(不能在检索的项开始使用*或者?符号) 
4. “~” 表示模糊检索,如检索拼写类似于”roam”的项这样写:roam~将找到形如foam和roams的单词;roam~0.8,检索返回相似度在0.8以上的记录。 
5. 邻近检索,如检索相隔10个单词的”apache”和”jakarta”,”jakarta apache”~10 
6. “^” 控制相关度检索,如检索jakarta apache,同时希望去让”jakarta”的相关度更加好,那么在其后加上”^”符号和增量值,即jakarta^4 apache 7. 布尔操作符AND、|| 8. 布尔操作符OR、&& 
9. 布尔操作符NOT、!、- (排除操作符不能单独与项使用构成查询) 10.“+” 存在操作符,要求符号”+”后的项必须在文档相应的域中存在 11. ( ) 用于构成子查询 
12. [] 包含范围检索,如检索某时间段记录,包含头尾,date:[200707 TO 200710] 13. {} 不包含范围检索,如检索某时间段记录,不包含头尾 date:{200707 TO 200710} 
   注:范围检索字段只适用于:String,int,dobule,date不能用于long型的字段 14. \ 转义操作符,特殊字符包括+ - && || ! ( ) { } [ ] ^ ” ~ * ? : \  
solr查询的一些常用语法  
1、首先假设我的数据里fields有:name, tel, address 预设的搜寻是name这个字段, 如果要搜寻的数据刚好就是 name 这个字段,就不需要指定搜寻字段名称。  
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)   
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  所以结果会如下:  
<result name=”response” numFound=”1340″ start=”0″>  <doc>  
<str name=”name”>北京亿度</str>  
<str name=”address”>北京市海淀区上地软件园</str>  <str name=”tel”>88xxxxxx1</str>  </doc>  <doc>  
<str name=”name”>北京亿度</str>  <str name=”address”/>  
<str name=”tel”>88xxxxxx1</str>  </doc>  </result>   
4、查询 name 或 address:直接输入查询词, 如: 亿度  送出的内容即为:  
name:亿度 AND address:海淀   
5、若要搜寻联集结果,请在词与词间空格或加上大写 “OR” (不包含”号).  例如: text:海淀 OR text:亿度  text:海淀 OR 亿度   或  
海淀 亿度  或  
name:亿度 OR tel:88xxxxxx1  或  
name:亿度 tel:88xxxxxx1  
6、若要搜寻交集结果,请在词与词间加上大写 “AND” 或 “+” (不包含”号).  例如: text:海淀 AND 亿度   或  
+text:海淀 +text:亿度  或  
name:亿度 AND tel:88xxxxxx1  或  
name: ( +亿度 +海淀)   
7、排除查询  
在要排除的词前加上 “-” (不包含”号) 号  例如: 海淀 -亿度  
搜寻结果不会有包含亿度的词的结果在内   
8、Group 搜寻  
使用 “()” 来包含一个group  
如希望搜寻在店名字段内同时有 “台北”(不包含”号) 及 “火车站”(不包含”号)

9、增加权重: 如要搜寻 “北京 加油站”(不包含”号) 但因为回传太多笔资料内有 “中华”(不包含”号) 或 “加油站”(不包含”号) 的结果,  
所以想要把有包含 “加油站”(不包含”号)的数据往前排,可使用 “^”(不包含”号)符号在后面加上愈增加的权重数,  
像是 “2″,则可以这样做:  北京 加油站^2  
会同时搜寻含有北京或加油站的结果,并把加油站这个词加权所以搜寻时会先判断加油站这一个词在搜寻结果中的比重,甚至假设一笔数据内加油站出现过两次以上的就更加会有优先权。 查询时在查询词后加上 “^” (不包含”号) 再加上权重分数  例如: 亿度 AND “北京”^2  或  
亿度^2 OR 北京   
10、Wildcard 搜寻使用 “*” 符号; 如果输入 “中国*银” (不包含”号), 结果会有中国信托商业银行, 中国输出入银行图书阅览室, 中国商银证券  中国及银之间可夹任何长短字词.

时间: 2024-10-10 23:32:10

solr 查询的相关文章

Solr查询详解

一. 查询参数说明 在做solr查询的时候,solr提供了很多参数来扩展它自身的强大功能!以下是使用频率最高的一些参数! 1.常用 q - 查询字符串,这个是必须的.如果查询所有*:* ,根据指定字段查询(Name:张三 AND Address:北京) fq - (filter query)过虑查询,作用:在q查询符合结果中同时是fq查询符合的,例如:q=Name:张三&fq=CreateDate:[20081001 TO 20091031],找关键字mm,并且CreateDate是200810

solr与.net系列课程(四)solr查询参数的讲解与.net如何获取solr数据

solr与.net系列课程(四)solr查询参数的讲解与.net如何获取solr数据 上一节我们完成了solr连接数据库,细心的朋友会发现一个问题,就是solr其实和语言没有任何关系,配置完成后任何语言都可以直接调用,本章我们主要对solr的查询做出讲解,然后就是新接触的人最关心的.net如何获取solr中的数据. 本节我准备了一个300万左右的数据表,为大家做演示 然后我们开始配置schema.xml 文件: <field name="id" type="string

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

今天还是不会涉及到java和数据库操作,主要还是总结Solr 的查询参数,还是那句话,只有先明白了solr的基础内容和查询语法,后续学习solr 的java和数据库操作,都是水到渠成的事.这里先列出solr查询所需要的参数 wiki 地址:http://wiki.apache.org/solr/FrontPage, 里面有各个参数详细的介绍. 一.基本查询 q  查询的关键字,此参数最为重要,例如,q=id:1,默认为q=*:*, fl  指定返回哪些字段,用逗号或空格分隔,注意:字段区分大小写

7.Solr查询参数

一.基本查询 q  查询的关键字,此参数最为重要,例如,q=id:1,默认为q=*:*, fl  (field list)指定返回哪些字段,用逗号或空格分隔,注意:字段区分大小写,例如,fl= id,title,sort start  返回结果的第几条记录开始,一般分页用,默认0开始 rows  指定返回结果最多有多少条记录,默认值为 10,配合start实现分页 sort  排序方式,例如price asc, id desc wt  (writer type)指定输出格式,有 xml, jso

Solr查询语法笔记

1.常用  q - 查询字符串,这个是必须的.如果查询所有*:* ,根据指定字段查询(Name:张三 AND Address:北京) fq - (filter query)过虑查询,作用:在q查询符合结果中同时是fq查询符合的,例如:q=Name:张三&fq=CreateDate:[20081001 TO 20091031],找关键字mm,并且CreateDate是20081001 fl - 指定返回那些字段内容,用逗号或空格分隔多个. start - 返回第一条记录在完整找到结果中的偏移位置,

solr查询语法(solr query)

1. CoreQueryParam查询的参数  1) q: 查询字符串,必须的. 2) q.op: 覆盖schema.xml的defaultOperator(有空格时用"AND"还是用"OR"操作逻辑),一般默认指定. 3) df: 默认的查询字段,一般默认指定. 4) qt: query type,指定查询使用的Query Handler,默认为"standard". 5) wt: writer type.指定查询输出结构格式,默认为"

solr查询域为空值的方法

例,我想查找内容字段content为空值的文档,看看文档有多少?执行如下查询. http://127.0.0.1:11100/solr/province/select?q=-(content:*)&wt=json&indent=true

Solr查询参数

引自:http://www.cnblogs.com/zhangweizhong/p/5056884.html 一.基本查询 q  查询的关键字,此参数最为重要,例如,q=id:1,默认为q=*:*, fl  指定返回哪些字段,用逗号或空格分隔,注意:字段区分大小写,例如,fl= id,title,sort start  返回结果的第几条记录开始,一般分页用,默认0开始 rows  指定返回结果最多有多少条记录,默认值为 10,配合start实现分页 sort  排序方式,例如id  desc 表

Solr自学笔记 2 —— Solr 查询,排序, 高亮

1.查询(Querying Data) --q 文档 fl 表示相应的属性 1) 内容: 搜索过程是通过带q参数的GET HTTP请求select URL.同时可以通过传递表示可选择的请求参数的数字给请求处理器来控制相应的返回信息.(You can pass a number of optional request parameters to the request handler to control what information is returned) 下面f1参数来控制相应的返回的属