使用C#代碼實(shí)現(xiàn)對(duì)ElastiSearch的編程查詢,是十分方便的,通常情況下,開(kāi)發(fā)者采用官方提供的NEST客戶端程序,通過(guò)封裝的方法向ElasticSearch引擎發(fā)送查詢請(qǐng)求,搜索數(shù)據(jù),最終獲取返回的查詢結(jié)果,實(shí)現(xiàn)預(yù)定的業(yè)務(wù)需求。在內(nèi)部,NEST客戶端通過(guò)格式化的數(shù)據(jù)結(jié)構(gòu),把C#代碼轉(zhuǎn)換成HTTP 請(qǐng)求(Request),減輕了用戶直接編寫Qeury DSL的麻煩。當(dāng)然,用戶也可以直接把Query DSL封裝成HTTP請(qǐng)求,發(fā)送到ElasticSearch引擎;對(duì)開(kāi)發(fā)者來(lái)說(shuō),不僅需要熟悉Query DSL的語(yǔ)法,而且需要手動(dòng)編寫代碼,處理引擎返回的JSON結(jié)構(gòu)化的數(shù)據(jù)集,采用這種方式的優(yōu)點(diǎn)是不受限于NEST客戶端程序,能夠最大化使用ElasticSearch查詢的各種參數(shù),書(shū)寫自由。
本文簡(jiǎn)單介紹使用C#代碼對(duì)ElasticSearch進(jìn)行編程查詢的流程,具體的細(xì)節(jié),請(qǐng)參考官方文檔。
一,編程流程
1,創(chuàng)建客戶端
在搜索文檔之前,首先要連接到ElasticSearch引擎,創(chuàng)建客戶端對(duì)象
using Nest;var node = new Uri("http://myserver:9200");var settings = new ConnectionSettings(node).DefaultIndex("default");var client = new ElasticClient(settings);
2,創(chuàng)建查詢請(qǐng)求
連接到引擎之后,創(chuàng)建搜索請(qǐng)求(SearchRequest),用于封裝查詢類型和查詢條件
SearchRequest sr = new SearchRequest("meetup", "events");
3,指定查詢類型和查詢條件
為搜索請(qǐng)求指定查詢類型,可以是詞條搜索,或全文搜索
TermQuery tq = new TermQuery(); tq.Field = "eventname"; tq.Value = "azure"; sr.Query = tq;
4,調(diào)整查詢結(jié)果
為搜索請(qǐng)求設(shè)置參數(shù),排序,分頁(yè),和選擇返回的字段等,在選擇查詢結(jié)果返回的字段時(shí),推薦在查詢請(qǐng)求(SearchRequest)中使用Source Filter。
在查詢請(qǐng)求中,通過(guò)類RequestSearch的數(shù)組字段StoredFileds,把已存儲(chǔ)字段添加到該數(shù)組中,ElasticSearch引擎只返回特定的字段,而不是文檔的所有字段。在索引映射中,已存儲(chǔ)字