利用SOLR搭建企业搜索平台 之九(solr的查询语法)
利用SOLR搭建企业搜索平台 之九(solr的查询语法)
博客分类: solrsolr的一些查询语法
1.首先假设我的数据里fields有:name,tel,address预设的搜寻是name这个字段,如果要搜寻的数据刚好就是name这个字段,就不需要指定搜寻字段名称.
2.查询规则:
如欲查询特定字段(非预设字段),请在查询词前加上该字段名称加“:”(不包含”号)符号,
例如:address:北京市海淀区上地软件园tel:88xxxxx1
1>.q代表queryinput
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
所以结果会如下:
<resultname=”response”numFound=”1340″start=”0″>
<doc>
<strname=”name”>北京亿度</str>
<strname=”address”>北京市海淀区上地软件园</str>
<strname=”tel”>88xxxxxx1</str>
</doc>
<doc>
<strname=”name”>北京亿度</str>
<strname=”address”/>
<strname=”tel”>88xxxxxx1</str>
</doc>
</result>
5.查询name或address:直接输入查询词,如:亿度
送出的内容即为:
name:亿度ANDaddress:海淀
6.若要搜寻联集结果,请在词与词间空格或加上大写“OR”(不包含”号).
例如:text:海淀ORtext:亿度
text:海淀OR亿度
或
海淀亿度
或
name:亿度ORtel:88xxxxxx1
或
name:亿度tel:88xxxxxx1
5.若要搜寻交集结果,请在词与词间加上大写“AND”或“+”(不包含”号).
例如:text:海淀AND亿度
或
+text:海淀+text:亿度
或
name:亿度ANDtel:88xxxxxx1
或
name:(+亿度+海淀)
6.排除查询
在要排除的词前加上“-”(不包含”号)号
例如:海淀-亿度
搜寻结果不会有包含亿度的词的结果在内
7.Group搜寻
使用“()”来包含一个group
如希望搜寻在店名字段内同时有“台北”(不包含”号)及“火车站”(不包含”号)
8.增加权重:如要搜寻“北京加油站”(不包含”号)但因为回传太多笔资料内有“中华”(不包含”号)或“加油站”(不包含”号)的结果,
所以想要把有包含“加油站”(不包含”号)的数据往前排,可使用“^”(不包含”号)符号在后面加上愈增加的权重数,
像是“2″,则可以这样做:
北京加油站^2
会同时搜寻含有北京或加油站的结果,并把加油站这个词加权所以搜寻时会先判断加油站这一个词在
搜寻结果中的比重,甚至假设一笔数据内加油站出现过两次以上的就更加会有优先权.
查询时在查询词后加上“^”(不包含”号)再加上权重分数
例如:亿度AND“北京”^2
或
亿度^2OR北京
9.Wildcard搜寻使用“*”符号;如果输入“中国*银”(不包含”号),结果会有中国信托商业银行,中国输出入银行图书阅览室,中国商银证券
中国及银之间可夹任何长短字词.