您好,登錄后才能下訂單哦!
這篇“l(fā)aravel如何使用es”文章,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要參考一下,對于“l(fā)aravel如何使用es”,小編整理了以下知識點,請大家跟著小編的步伐一步一步的慢慢理解,接下來就讓我們進入主題吧。
Laravel 是一套簡潔、優(yōu)雅的PHP Web開發(fā)框架。它可以讓你從面條一樣雜亂的代碼中解脫出來;它可以幫你構(gòu)建一個完美的網(wǎng)絡APP,而且每行代碼都可以簡潔、富于表達力。
Elasticsearch 簡介
Elastic 的底層是開源庫 Lucene。但是,你沒法直接用 Lucene,必須自己寫代碼去調(diào)用它的接口。Elastic 是 Lucene 的封裝,提供了 REST API 的操作接口,開箱即用。
ES 和 Mysql
ES 里的概念類比于 Mysql 如下圖所示:
倒排索引
在說倒排索引之前我們先說說什么是正排索引。正排索引也稱為”前向索引”,它是創(chuàng)建倒排索引的基礎(chǔ)。
如上在查詢一個 keyword 在哪些文檔里包含的時候,需對所有的文檔進行掃描以確保沒有遺漏,這樣就使得檢索時間大大延長,檢索效率低下。這個時候我們就用到了倒排索引,首先將文檔分詞。
比如我們要查詢‘搜索引擎’這個關(guān)鍵詞在哪些文檔中出現(xiàn)過。首先我們通過倒排索引可以查詢到該關(guān)鍵詞出現(xiàn)的文檔位置是在1和3中;然后再通過正排索引查詢到文檔1和3的內(nèi)容并返回結(jié)果。
Laravel 使用 ES
安裝插件
basemkhirat/elasticsearch 是 Laravel 中使用 ES 的一個擴展,使用起來非常方便:
1)安裝方法
$ composer require basemkhirat/elasticsearch
2)發(fā)布
$ php artisan vendor:publish –provider=”Basemkhirat\Elasticsearch\ElasticsearchServiceProvider”
配置
這樣我們就安裝好了,如下是我們的連接配置:
'connections' => [ 'default' => [ 'servers' => [ [ "host" => env("ELASTIC_HOST", "127.0.0.1"), "port" => env("ELASTIC_PORT", 9200), 'user' => env('ELASTIC_USER', ''), 'pass' => env('ELASTIC_PASS', ''), 'scheme' => env('ELASTIC_SCHEME', 'http'), ] ], 'index' => env('ELASTIC_INDEX', 'my_index') ]],
servers 里可以加入我們的集群配置。
使用方法
該插件的使用方法可借鑒 Laravel 的查詢構(gòu)造器,支持常用的如 where
、whereIn
、whereBetween
、orderBy
、first
、get
,也支持分頁方法paginate
。
$documents = ES::connection(“default”)
->index(“my_index”)
->type(“my_type”)
->get(); # return a collection of results
設置字段權(quán)重:
ES::type(“my_type”)->search(“hello”, function($search){
$search->boost(2)->fields([“title” => 2, “content” => 1])
})->get();
我們也可以通過修改源碼擴充自己需要用到的方法,也可以構(gòu)造原生的查詢語句:
$params['body'] = [ 'aggs' => [ 'all_created' => [ 'terms' => [ 'field' => 'element.raw', 'size' => $this->_mAggsPageSize ], 'aggs' => [ 'sum_pv' => [ 'sum' => ['field' => 'pv'], ], ], ], ], ];
以上是“l(fā)aravel如何使用es”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。