1. 程式人生 > >solr客戶端查詢語法

solr客戶端查詢語法

1、常用查詢引數說明 
    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"操作邏輯),一般預設指定  “OR”
    df - 預設的查詢欄位,一般預設指定 
    qt - (query type)指定那個型別來處理查詢請求,一般不用指定,預設是standard。 
    其它 
    indent - 返回的結果是否縮排,預設關閉,用 indent=true|on 開啟,一般除錯json,php,phps,ruby輸出才有必要用這個引數。 
    version - 查詢語法的版本,建議不使用它,由伺服器指定預設值。
   
    solrconfig.xml的配置例項
查詢配置(以上引數項都可以配置到該配置檔案)
<requestHandler name="/select" class="solr.SearchHandler">
     <lst name="defaults">
       <str name="echoParams">explicit</str>
       <int name="rows">10</int>

       <str name="defType">edismax</str>   //使用的是solr 擴充套件的查詢解析器

      <str name="q.alt">*:*</str>
      <str name="fq">sell_price:[1 TO *]</str>
      <str name="hl">true</str>
      <str name="hl.fl">room_name</str>
           <str name="bf">sum(product(termfreq(room_status,"dzz"),1.2),1)</str> //額外的評分欄位,這個是可以影響score的打分的
      <str name="pf">  //要查詢的欄位
            room_name house_code room_code zr_house_code hire_commissioner_name broker_name rating_address resblock_name district_name subway_station_name subway_line_name
      </str>
      <str name="qf"> //各自段分配的權重
            room_name^5 house_code room_code zr_house_code  hire_commissioner_name broker_name rating_address resblock_name^2 district_name subway_station_name subway_line_name
      </str>
     </lst>
</requestHandler>

另外schema.xml的defaultOperator引數是個很重要的引數,預設是“OR”,意思是要查詢的關鍵詞做完分詞後的詞做 “OR”連線,然後再做查詢,而“AND”呢,要至少全包含要搜尋的關鍵詞才行。

2、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}
     " 轉義操作符,特殊字元包括+ -² && || ! ( ) { } [ ] ^ ” ~ * ? : "
    
非空資料的查詢 比如:fq=fcode:['' TO *] 查詢fcode非空的資料

取反例項:fq=!fstate:1

3、facet查詢

分類統計 facet 
    q=*:*&facet=true&facet.field=cat&facet.field=inStock  //按cat  inStock進行分類統計
   
    q=ipod&facet=true&facet.query=price:[0 TO 100]&facet.query=price:[100 TO *]  //區間統計 價格在0-100 和100-無窮大的

--solr的分組查詢(facet)
http://IP:port/solr/room/select?rows=0&q=bizcircle_code:XXXXXX&facet=on
&facet.field=resblock_id&facet.field=resblock_name&facet.limit=3   //同一個bizcircle_code下的 前三個resblock 各自的文件數量

在做solr查詢的時候,solr提供了很多引數來擴充套件它自身的強大功能!以下是使用頻率最高的一些引數! 

1、常用 

q - 查詢字串,這個是必須的。如果查詢所有*:* ,根據指定欄位查詢(Name:張三 AND Address:北京

fq - (filter query)過慮查詢,作用:在q查詢符合結果中同時是fq查詢符合的,例如:q=Name:張三&fq=CreateDate:[20081001 TO 20091031],找關鍵字mm,並且CreateDate是20081001

fl - 指定返回那些欄位內容,用逗號或空格分隔多個。 

start - 返回第一條記錄在完整找到結果中的偏移位置,0開始,一般分頁用。 

rows - 指定返回結果最多有多少條記錄,配合start來實現分頁。 

sort - 排序,格式:sort=<field name>+<desc|asc>[,<field name>+<desc|asc>]… 。示例:(score desc, price asc)表示先 “score” 降序, 再 “price” 升序,預設是相關性降序。 

wt - (writer type)指定輸出格式,可以有 xmljsonphpphps。 

fl表示索引顯示那些field( *表示所有field,如果想查詢指定欄位用逗號或空格隔開(如:Name,SKU,ShortDescription或Name SKU ShortDescription【注:欄位是嚴格區分大小寫的)) 

q.op 表示q 中 查詢語句的 各條件的邏輯操作 AND(與) OR(或) 

hl 是否高亮 ,如hl=true

hl.fl 高亮field ,hl.fl=Name,SKU

hl.snippets :預設是1,這裡設定為3個片段

hl.simple.pre 高亮前面的格式 

hl.simple.post 高亮後面的格式 

facet 是否啟動統計 

facet.field  統計field 

【注:以上是比較常用的引數,當然具體的引數使用還是多看Solr官方的技術文件以及一些大神的博文日誌,這裡只是拋磚引玉】

二、 Solr運算子

1. “:” 指定欄位查指定值,如返回所有值*:*

2. “?” 表示單個任意字元的通配

3. “*” 表示多個任意字元的通配(不能在檢索的項開始使用*或者?符號)

4. “~” 表示模糊檢索,如檢索拼寫類似於”roam”的項這樣寫:roam~將找到形如foam和roams的單詞;roam~0.8,檢索返回相似度在0.8以上的記錄。

5. 鄰近檢索,如檢索相隔10個單詞的”apache”和”jakarta”,”jakarta apache”~10

6. “^” 控制相關度檢索,如檢索jakarta apache,同時希望去讓”jakarta”的相關度更加好,那麼在其後加上”^”符號和增量值,即jakarta^4 apache

7. 布林操作符AND、||

8. 布林操作符OR、&&

9. 布林操作符NOT、!、- (排除操作符不能單獨與項使用構成查詢)
10. “+” 存在操作符,要求符號”+”後的項必須在文件相應的域中存在
11. ( ) 用於構成子查詢
12. [] 包含範圍檢索,如檢索某時間段記錄,包含頭尾,date:[200707 TO 200710]
13. {} 不包含範圍檢索,如檢索某時間段記錄,不包含頭尾
date:{200707 TO 200710}
14. / 轉義操作符,特殊字元包括+ - && || ! ( ) { } [ ] ^ ” ~ * ? : /

 注:①“+”和”-“表示對單個查詢單元的修飾,and 、or 、 not 是對兩個查詢單元是否做交集或者做差集還是取反的操作的符號

   比如:AB:china +AB:america ,表示的是AB:china忽略不計可有可無,必須滿足第二個條件才是對的,而不是你所認為的必須滿足這兩個搜尋條件

   如果輸入:AB:china AND AB:america ,解析出來的結果是兩個條件同時滿足,即+AB:china AND +AB:america或+AB:china +AB:america

  總而言之,查詢語法:  修飾符 欄位名:查詢關鍵詞 AND/OR/NOT 修飾符 欄位名:查詢關鍵詞

三、 Solr查詢語法

1.最普通的查詢,比如查詢姓張的人( Name:張),如果是精準性搜尋相當於SQL SERVER中的LIKE搜尋這需要帶引號(""),比如查詢含有北京的(Address:"北京")

2.多條件查詢,注:如果是針對單個欄位進行搜尋的可以用(Name:搜尋條件加運算子(OR、AND、NOT) Name:搜尋條件),比如模糊查詢( Name:張 OR Name:李 )單個欄位多條件搜尋不建議這樣寫,一般建議是在單個欄位裡進行條件篩選,如( Name:張 OR 李),多個欄位查詢(Name:張 + Address:北京 

3.排序,比如根據姓名升序(Name asc),降序(Name desc


facet使用的參考例子

相關推薦

solr客戶查詢語法

1、常用查詢引數說明      q - 查詢字串,必須的。      fl - 指定返回那些欄位內容,用逗號或空格分隔多個。      start - 返回第一條記錄在完整找到結果中的偏移位置,0開始,一般分頁用。      rows - 指定返回結果最多有多少條記錄,配合start來實現分頁。 

配置solr客戶(全文搜索服務器)

服務 nbsp group per tid 客戶端 pre artifact rop <properties> <solrj.version>4.10.3</solrj.version> </properties>

Redis客戶查詢緩衝區和輸出緩衝區

每個Redis客戶端(以下簡稱”Client”)都有多個狀態屬性,而理解和分析這些屬性,對於我們設計Redis鍵空間和運營管理都有幫助。 本文將詳細分析Client的兩個重要屬性:Query buffer(輸入緩衝區)、Output buffers(輸出緩衝區) Re

Spring-Boot 整合Solr客戶

tips: IDEA的快速查詢類快捷鍵 (連續按兩次 shift 鍵) 1) maven配置: <parent> <groupId>org.springframework.boot</groupId>

HBase 客戶 Shell語法以及Java API 的使用

HBase 客戶端 Shell語法以及Java API 的使用 本章介紹用於對HBase表上執行CRUD操作的HBase Java客戶端API。  HBase是用Java編寫的,並具有Java原生API。因此,它提供

全文索引----solr客戶工具solrJ

      上一篇部落格中,我們使用solr的桌面客戶端工具展示返回的資料,如果我們需要在程式中使用這些返回值的話,就需要另外的一個工具了----solrJ。 一 solrJ介紹     1 是什麼

以太坊go-ethereum客戶查詢交易列表(二)

玩過比特幣的朋友都知道,比特幣是可以通過api(listtransactions)查詢指定地址的歷史交易的。但在eth中沒有提供類似的查詢api。今天這篇部落格就簡單介紹一下如果解決這個問題。 問題 以太坊go-ethereum客戶端是沒有根據地址查詢交

【Apache Solr系列之三】Solr客戶SolrJ API使用文件-增刪改

通過之前兩篇文章的學習之後,使用solr對mysql進行資料匯入以及增量索引應該都會了! 接下來我們學習下如果從Solr中讀取我們想要的資料。同時你也可以結合Solr的web介面進行驗證,看看你的查詢結果是否正確。 環境準備: 從之前下載的solr安裝包中解壓獲取以下ja

Solr 4.10.3 客戶 SolrJ 進行 查詢檢索 操作

本文導讀 基本檢索 package com.wmx.utils; import com.wmx.domain.News; import org.apache.solr.client.solrj.SolrQuery; import org.apache.solr.cl

PHP客戶 solr查詢具體實現

Sorl簡介 Solr是一個基於Lucene的Java搜尋引擎伺服器。Solr 提供了層面搜尋、命中醒目顯示並且支援多種輸出格式(包括 XML/XSLT 和 JSON 格式)。它易於安裝和配置,而且附帶了一個基於 HTTP 的管理介面。Solr已經在眾多大型的

HBase 常用java api獲得客戶,創建表,查詢,刪除

size 列族 war pen 需要 java pool 數據類型 init 1,前期準備 (1) 本文采用的hbase是采用三臺服務器搭建的集群,zookeeper也是相同服務器搭建的集群,集群ip分別是192.168.183.101; 192.168.183.102;

redis客戶連接,最大連接數查詢與設置

指定 col node 網絡 service服務 限制 style nbsp free ##redis客戶端連接數 redis通過監聽一個TCP端口或socket的方式接收來自客戶端的連接, 當與客戶端建立連接後,redis內部會進行如下操作:(1)客戶端socket會

【vbs】查詢客戶上的應用程序

spa uninstall fault play windows const war str jre 方法一: strHost?=?"."Const?HKLM?=?&H80000002Set?objReg?=?GetObject("winmgmts://"?&

ES操作java客戶client查詢語句,模糊查詢

    sourceType:es索引名稱 fields:輸出欄位的陣列 fields[0],指定欄位,進行模糊查詢. start_time:條件查詢的時間段.可以是String型別 "yyyy-MM-dd hh:mm:ss"; setSize(1000)

如何實現在客戶或瀏覽器頁面中整合一個類似plsqldeveloper一樣的查詢功能?

轉載:https://ask.csdn.net/questions/703108 qq_16127313  https://gitee.com/00fly/effict-side/tree/master/dbtool-springboot 專案運維過程中,受到客戶機房管理

Redis客戶基本操作以及檢視慢查詢

1.連線 redis-cli.exe -h 127.0.0.1 -p 6379 2.驗證密碼 λ redis-cli.exe -h 127.0.0.1 -p 6379127.0.0.1:6379> auth 密碼 3. redis key值獲取    

Visual C++網路程式設計經典案例詳解 第4章 FTP瀏覽器 建立客戶 使用CFtp類程式設計 初始化檔案查詢

使用者在客戶端啟動時 可以使用函式進行檔案查詢 BOOL CFTPDlg::OnInitDialog() { ... //省略部分程式碼 int i=0; LVITEM item={0}; //初始化列表結構 item.mask=LVIF_TEXT;

solr 查詢語法解析

solr的查詢語法是solr應用中查詢的基礎,下文將介紹一下solr查詢中的基礎語法。 內建查詢函式 如果你想自定義搜尋結果打分機制的話,你可以組合solr內建的函式。一般情況下,你可以設定defType=edismax;bf=[自定義函式] 來設定打分機制進行排序。

Solr查詢語法總結-引數說明

1、常用查詢引數說明       q - 查詢字串,必須的。       fl - 指定返回那些欄位內容,用逗號或空格分隔多個。       start - 返回第一條記錄在完整找到結果中的偏移位置,0開始,一般分頁用。       rows - 指定返回結果最多有多少條

Jest客戶索引新增、資料查詢、分頁例項

/** * 〈一句話功能簡述〉操作ES的Jest客戶端<br> * 〈功能詳細描述〉 * * @author wangzha * @see [相關類/方法](可選) * @since [產品/模組版本] (可選) */ @Se