`

solr的一些查询语法

    博客分类:
  • solr
 
阅读更多

1. 预设查询

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

 

2. 查询规则: 

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

例如: address:台北台北市中正区重庆南路一段xxx号 tel:23xxxxx1

 

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:台北 台北市中正区重庆南路一段xxx号+tel:23xxxxx1&version=2.2&start=10&rows= 20&indent=on 

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

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

http: //localhost:8080/solr/select/?indent=on&version=2.2&q=text:总统府+ OR+text:邮局&start=0&rows=10&fl=name,subbranch,tel 

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

所以结果会如下: 

<result name=”response” numFound=”1340″ start=”0″> 
<doc> 
<str name=”name”>总统府邮局</str> 
<str name=”subbranch”>台北15支</str> 
<str name=”tel”>23xxxxxx9</str> 
</doc>
 
<doc> 
<str name=”name”>总统府</str> 
<str name=”subbranch”/> 
<str name=”tel”>23xxxxxx1</str> 
</doc> 
</result>

 

3. 与操作 (同时满足多个条件)

查询 name 或 subbranch:直接输入查询词, 如: 7-eleven 忠孝店 

送出的内容即为: 

name:7-eleven AND subbrahch:忠孝店

 

4. 或操作 (满足多个条件的一个即可)

若要搜寻联集结果,请在词与词间空格或加上大写 “OR” (不包含”号). 

例如: text:总统府 OR text:邮局 

text:总统府 OR 邮局 

或 

总统府 邮局 

或 

name:总统府 OR tel:23xxxxxx3 

或 

name:总统府 tel:23xxxxxx3

或 

name:总统府+tel:23xxxxxx3

 

5. 查询一个范围 BETWEEN

NUM:[-90 TO 360 ]  OR CREATED_AT:[" + date1 + " TO " + date2 + "]  

 

//------------------- 以下的本人未测试 -------------------------------

5. 排除查询 

在要排除的词前加上 “-” (不包含”号) 号 

例如: 总统府 -邮局 

搜寻结果不会有包含邮局的词的结果在内

 

6. Group 搜寻 

使用 “()” 来包含一个group 

如希望搜寻在店名字段内同时有 “台北”(不包含”号) 及 “火车站”(不包含”号)

 

7. 增加权重

如要搜寻 “中华 加油站”(不包含”号) 但因为回传太多笔资料内有 “中华”(不包含”号) 或 “加油站”(不包含”号) 的结果, 

所以想要把有包含 “加油站”(不包含”号)的数据往前排,可使用 “^”(不包含”号)符号在后面加上愈增加的权重数, 

像是 “2″,则可以这样做:

中华 加油站^2

 

会同时搜寻含有中华或加油站的结果,并把加油站这个词加权所以搜寻时会先判断加油站这一个词在 

搜寻结果中的比重,甚至假设一笔数据内加油站出现过两次以上的就更加会有优先权.

 

查询时在查询词后加上 “^” (不包含”号) 再加上权重分数 

例如: 总统府 AND “邮局”^2 

或 

总统府^2 OR 邮局

 

8. Wildcard 搜寻使用 “*” 符号; 如果输入 “中国*银” (不包含”号), 结果会有中国信托商业银行, 中国输出入银行图书阅览室, 中国商银证券 

中国及银之间可夹任何长短字词.

 

 

------------------------------------------ solr 查询实例 ------------------------------------------------------------

1. 非空值的方法

q=FieldName:['' TO *]

相当于在sql中执行:

SELECT field_name FROM some_table WHERE field_name IS NOT NULL;

 

2. 数字大小查询

查询某列大于0的记录

q=FieldName:[1 TO *]

对应的sql:

SELECT field_name FROM some_table WHERE field_name > 0;

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics