solr的一些查询语法
1. 首先假设个人数据里fields有:name, subbranch, tel, address 预设的搜寻是name这个字段, 若是要搜寻的数据恰好就是 name 这个字段,就不须要指定搜寻字段名称.
2. 查询规则:
如欲查询特定字段(非预设字段),请在查询词前加上该字段名称加 “:” (不包含”号) 符号,
例如: address:台北台北市中正区重庆南路一段xxx号 tel:23xxxxx1 xml
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 input
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> io
<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:忠孝店 select
4. 若要搜寻联集结果,请在词与词间空格或加上大写 “OR” (不包含”号).
例如: text:总统府 OR text:邮局
text:总统府 OR 邮局
或
总统府 邮局
或
name:总统府 OR tel:23xxxxxx3
或
name:总统府 tel:23xxxxxx3 语法
5. 若要搜寻交集结果,请在词与词间加上大写 “AND” 或 “+” (不包含”号).
例如: text:总统府 AND text:邮局
或
+text:总统府 +text:邮局
或
name:总统府 AND tel:23xxxxxx3
或
name: ( +总统府 +邮局) 数据
6. 排除查询
在要排除的词前加上 “-” (不包含”号) 号
例如: 总统府 -邮局
搜寻结果不会有包含邮局的词的结果在内 查询
7. Group 搜寻
使用 “()” 来包含一个group
如但愿搜寻在店名字段内同时有 “台北”(不包含”号) 及 “火车站”(不包含”号) di
8. 增长权重: 如要搜寻 “中华 加油站”(不包含”号) 但由于回传太多笔资料内有 “中华”(不包含”号) 或 “加油站”(不包含”号) 的结果,
因此想要把有包含 “加油站”(不包含”号)的数据往前排,可以使用 “^”(不包含”号)符号在后面加上愈增长的权重数,
像是 “2″,则能够这样作: solr
中华 加油站^2
会同时搜寻含有中华或加油站的结果,并把加油站这个词加权因此搜寻时会先判断加油站这一个词在
搜寻结果中的比重,甚至假设一笔数据内加油站出现过两次以上的就更加会有优先权.
查询时在查询词后加上 “^” (不包含”号) 再加上权重分数
例如: 总统府 AND “邮局”^2
或
总统府^2 OR 邮局
9. Wildcard 搜寻使用 “*” 符号; 若是输入 “中国*银” (不包含”号), 结果会有中国信托商业银行, 中国输出入银行图书阅览室, 中国商银证券 中国及银之间可夹任何长短字词.