solr的一些查询语法

2019-03-27 01:27|来源: 网路

 

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

 

1.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)

 

1.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

3、查询参数

常用

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”操作逻辑),一般默认指定
df – 默认的查询字段,一般默认指定
qt – (query type)指定那个类型来处理查询请求,一般不用指定,默认是standard。
其它

indent – 返回的结果是否缩进,默认关闭,用 indent=true|on 开启,一般调试json,php,phps,ruby输出才有必要用这个参数。
version – 查询语法的版本,建议不使用它,由服务器指定默认值。
[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}
timestamp:[* TO NOW]
createdate:[1976-03-06T23:59:59.999Z TO *]
createdate:[1995-12-31T23:59:59.999Z TO 2007-03-06T00:00:00Z]
pubdate:[NOW-1YEAR/DAY TO NOW/DAY+1DAY]
createdate:[1976-03-06T23:59:59.999Z TO 1976-03-06T23:59:59.999Z+1YEAR]
createdate:[1976-03-06T23:59:59.999Z/YEAR TO 1976-03-06T23:59:59.999Z]
” 转义操作符,特殊字符包括+ – & | ! ( ) { } [ ] ^ ” ~ * ? : “


转自:http://www.solr.cc/blog/?p=1018

相关问答

更多
  • 我找到了解决方案:当我执行否定查询时,我必须写: *:* - 对于我的问题,解决方案是: time:90000 OR (time:* -time:[1521 TO *] AND (time:* -(time:[* TO 1519] OR time:[1521 TO *]))) I found the solution: when I perform a negative query, I must write: *:* - For my issue, the solution i ...
  • 对于过滤器查询,如果未指定该字段,则查询将在默认字段上起作用。 您可以通过添加debugQuery=on来检查执行的过滤器查询 text:solr100 因此,检查默认字段是否应具有CABERNET术语。 此外,匹配将取决于字段类型,执行的分析以及字段索引与否的位置。 只有索引的字段才能过滤结果。 For the filter queries if the field is not speci ...
  • 经过大量的努力,我发现现在没有工具可以解析FAST ESP查询到Solr查询(语法方面)。 我必须发展自己的。 听说Solr开发团队正在尝试开发一种能够做到这一点的工具。 同时,您将不得不等待,或开发自己的工具。 在测试了我开发的那个 - 我将它发布供公众使用。 After a lot of effort, I found out there is no tool for now that can parse FAST ESP queries to Solr queries (syntax wise). I ...
  • 雅阿。 这是因为statusid字段。 对于indexed="false"的字段,您无法对其进行查询。 只需从查询中删除statusid部分,您的查询就可以正常工作。 q=(title:"Merkel" OR body:"Merkel" OR excerpt:"Merkel") AND sitecode:GIR Yaa. It's becasue of the statusid field. For a field if indexed="false", you can not query on it. ...
  • 问过solr-user组。 以下是Chris Hostetter的回答: 问题是你试图在没有任何引用的情况下将查询嵌套在彼此内部的方式 - 解析器没有表明“b”参数是if(exists(query({!v='user_type:ADMIN'})),10,1)它认为它是"if(exists(query({!v='user_type:ADMIN'" ,其余的混淆了它)。 如果你引用“b”参数到boost解析器,它应该工作... http://localhost:8983/solr/select?q={!boos ...
  • 好吧,我找到了解决方案,它只是使用facet.prefix参数 select?q = : &rows = 5&facet = true&facet.limit = 5&facet.field = productID&facet.sort = true&facet.prefix = EG7SpTw03mJ25vxS5jcB24 我得到的输出是: − ...
  • 您确定要在架构中使用的列的类型是: 并不是: Did you make sure the type of the column you are using in your ...
  • 为此不起作用: q={!func}docFreq(texto_completo,bug) 使用所有小写docfreq : q={!func}docfreq(texto_completo,bug) 我刚尝试过: q={!func}mul(tf(name,movie),idf(name,movie)) 在Solr 4.2.1中它工作正常。 我的字段名称是name (文本类型),我要找的术语是movie 。 更新 :至少需要Solr 4.0来使用它们。 请参阅http://wiki.apache.org/s ...
  • 这两个示例都没问题,并且具有相同的行为,您甚至可以从第一个示例中删除括号。 Both examples are OK and have the same behaviour, you could even remove parentheses from the first example.
  • 你不应该逃避括号和其他特殊字符\ 您的实际搜索字符串是: date_day_tdt:\[2015\-09\-01T00\:00\:00Z\ TO\ 2015\-09\-01T23\:59\:59Z\] 提示1:直接使用您的查询。 浏览器或solr客户端API将正确地转义字符: date_day_tdt:[2015-09-01T00:00:00Z TO 2015-09-01T23:59:59Z] 提示2:将echoParams = all追加到查询中。 然后解析的参数被打印在solr结果中。 You sh ...