1)安装方法
$ composer require basemkhirat/elasticsearch
2)发布
$ 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 的查询构造器,支持常用的如 where
、whereIn
、whereBetween
、orderBy
、first
、get
,也支持分页方法paginate
。
$documents = ES::connection(“default”)
->index(“my_index”)
->type(“my_type”)
->get(); # return a collection of results
设置字段权重:
ES::type(“my_type”)->search(“hello”, function($search){
$search->boost(2)->fields([“title” => 2, “content” => 1])
})->get();
我们也可以通过修改源码扩充自己需要用到的方法,也可以构造原生的查询语句:
$params['body'] = [ 'aggs' => [ 'all_created' => [ 'terms' => [ 'field' => 'element.raw', 'size' => $this->_mAggsPageSize ], 'aggs' => [ 'sum_pv' => [ 'sum' => ['field' => 'pv'], ], ], ], ], ];
结语
ES 内置分词器对中分支持并不友好,比较推荐的是 IK分词器,需要注意的是ik版本需要与ES的版本号保持一致。
以上就是关于laravel使用es的正确姿势的详细内容,更多请关注其它相关文章!