Solr 及 lucene 的 query 使用方法初級解說
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
5. 若要搜尋交集結果,請在詞與詞間加上大寫 “AND” 或 “+” (不包含”號).
例如: text:總統府 AND text:郵局
或
+text:總統府 +text:郵局
或
name:總統府 AND tel:23xxxxxx3
或
name: ( +總統府 +郵局)
6. 排除查詢
在要排除的詞前加上 “-” (不包含”號) 號
例如: 總統府 -郵局
搜尋結果不會有包含郵局的詞的結果在內
7. Group 搜尋
使用 “()” 來包含一個group
如希望搜尋在店名欄位內同時有 “台北”(不包含”號) 及 “火車站”(不包含”號)
8. 增加權重: 如要搜尋 “中華 加油站”(不包含”號) 但因為回傳太多筆資料內有 “中華”(不包含”號) 或 “加油站”(不包含”號) 的結果,
所以想要把有包含 “加油站”(不包含”號)的資料往前排,可使用 “^”(不包含”號)符號在後面加上愈增加的權重數,
像是 “2″,則可以這樣做:
中華 加油站^2
會同時搜尋含有中華或加油站的結果,並把加油站這個詞加權所以搜尋時會先判斷加油站這一個詞在
搜尋結果中的比重,甚至假設一筆資料內加油站出現過兩次以上的就更加會有優先權.
查詢時在查詢詞後加上 “^” (不包含”號) 再加上權重分數
例如: 總統府 AND “郵局”^2
或
總統府^2 OR 郵局
9. Wildcard 搜尋使用 “*” 符號; 如果輸入 “中國*銀” (不包含”號), 結果會有中國信託商業銀行, 中國輸出入銀行圖書閱覽室, 中國商銀證券
中國及銀之間可夾任何長短字詞.
10. 當然還有一些更深入的用法,這裡只是初級的解說,若有興趣可以看看 lucene 或 solr的 document.
转自一台湾网友的blog,现已打不开,这是google的网页快照上的内容。
分享到:
相关推荐
solr查询语法,solr常用查询语法汇总。
排序 / 高亮 / facet / spellcheck:拼写检查 / spatial:空间搜索 / 检索运算符:
Solr 5.3.1搜索引擎搭建详细教程(包括集成mysql、添加中文分词、添加同义词、查询语法等)
solr在window下的配置,solr(全文检索系统),solr是lucene的升华版,把数据库的数据导入到solr中,减少了数据库的压力,solr搜索代替并优化了like模糊查询,并且有中文分词器
solr技术分析及运用超详细教程solr开发指南,包括solr服务器搭建,新增数据库配置,配置增量更新,配置分词器,常见异常,删除默认字段,调试技巧,solr日志,,solr基本查询语法,solr多字段匹配,solri集成solr...
js-solr-highlighter 一个JavaScript库,用于基于lucene / solr查询语法中的查询突出显示HTML文本在浏览器或Node.js环境中运行基于和构建一般的突出显示过程为: 使用Lucene语法从查询中得出要突出显示的文本突出...
本文档记录了solr启动报错"文件名目录名或卷标语法不正确"问题的解决方法
3.6.1 搜索语法 39 3.6.2 排序 42 3.6.3 字段增加权重 42 3.6.4 Solr分词器、过滤器、分析器 42 3.6.5 Solr高亮使用 46 4 SolrJ的用法 46 4.1 搜索接口的调用实例 46 4.2 Solrj的使用说明 47 4.2.1 Adding Data to ...
基于solr-geo空间搜索 1、Solr的schema.xml配置 定义坐标field 2、Solr的data-config.xml配置 建立索引 3、java查询语法 坐标距离、分页、排序
提供了一套solr到elasticsearch的语法翻译引擎,兼容现有的solr语法。同时提供了基于注解的ORM功能, 自动完成实体类对象与elasticsearch结果之间的转换。 你只要进行简单的配置,系统便会会自动完成索引、type/...
简单搜索查询解析器 简单的 PHP 脚本解析搜索查询并转换为 SOLR 语法。
SQL语句实现按关健字模糊查询,并按匹配度排序
SOLR 对 Zotonic 的支持 该模块向 Zotonic 添加了对...大多数查询选项类似于查询搜索语法:http: ,但您可以使用 Solr 做更多更好的事情。 您可以重构现有查询(来自 m.search[{query ....}]): {% with m.search
最近项目组安排了一个任务,项目中用到了全文搜索,基于全文搜索 Solr,但是该 Solr 搜索云项目不稳定,经常查询不出来数据,需要手动全量同步,而且是其他团队在维护,依赖性太强,导致 Solr 服务一出问题,我们的...
Apache Solr的网站该存储库包含Solr网站的“源代码”。建立网站该网站使用语法编写,并使用构建到静态网站中。 每次推送到主分支时, 都会自动重建该站点,并且可以在上预览结果。 构建成功/失败电子邮件将发送到...
安装将此行添加到您的应用程序的Gemfile中: gem 'rspec-solr'然后执行: $ bundle或将其自己安装为: $ gem install rspec-solr用法有关支持的期望的语法,请参见MATCHERS.md 。例子: it "q of 'Buddhism' should ...
自述文件一个聊天机器人,查询各种SOLR索引。安装$ go get github.com/miku/halbot添加Solr别名在指定SOLR网址。启动服务器$ HAL_ADAPTER=irc HAL_IRC_USER=hal HAL_IRC_NICK=hal \ HAL_IRC_SERVER=x.y....
JSON 通过强大的配置智能默认备份支持字段类型Text, Numeric, Date支持查询类型Term, Phrase, Match, Match Phrase, PrefixConjunction, Disjunction, BooleanNumeric Range, Date Range人类条目的简单查询语法tf-...
文件,一些包含的例子,如果你不传递任何命令行参数的语法消息,以及源代码注释) 很少/没有单元测试; 请参阅主要代码以获取一些有用的注释 有关其他缺点,请参阅最后的 TODO 部分:-) 尽管有这些警告,我发现该工具...