abo/larasearch

4 Easier use laravel Search

Maintainers

Details

gitee.com/min_abo/larasearch.git

Installs: 51

Dependents: 0

Suggesters: 0

Security: 0

Type:laravel-package

0.1.22 2019-07-04 03:06 UTC

This package is not auto-updated.

Last update: 2025-01-15 14:56:52 UTC


README

介绍

laravel 快速易用搜索项目

人无完人,开源项目的发展离不开 踩坑&填坑. 
可以 提issue等Abo解决 / 自己动手解决问题.贡献自己的力量比抱怨帅气多了

No one is perfect, the development of open source projects can not be separated from the pit and fill pit. 
You can publish issue and wait for solution.
Or do-it-yourself problem solving. It's more handsome than complaining about.

安装教程

安装

composer require abo/larasearch

使用说明

发布项目配置文件

php artisan vendor:publish --provider="Abo\Larasearch\LarasearchServiceProvider"

如有需要数据同步脚本,还可以执行以下命令生成

php artisan larasearch:sync {table_name}

快速开始

新建索引数据

Route::get('test/create',function(\Abo\Larasearch\EsBuilder $builder){
    $result = $builder->index('index')->type('type')->create([
        'key' => 'value',
    ]);
    dump($result);
});

更新索引数据

Route::get('test/create',function(\Abo\Larasearch\EsBuilder $builder){
    $result = $builder->index('index')->type('type')->update('id',[
        'key' => 'value2',
    ]);
    dump($result);
});

删除索引

Route::get('test/create',function(\Abo\Larasearch\EsBuilder $builder){
    $result = $builder->index('index')->type('type')->delete('id');
    dump($result);
});

查询索引数据

Route::get('test/create',function(\Abo\Larasearch\Builder $builder){
    $builder = $builder->index('index')->type('type');
    
    //SQL:select ... where id = 1 limit 1;
    $result = $builder->whereTerm('id',1)->first();    
});

更多用法

增删改

public function create(array $data, $id = null, $key = 'id'): stdClass

public function update($id, array $data): bool

public function delete($id)

获取查询对象

getElasticSearch()

查询字段

public function select($columns): self

条件

精准查询

$builder->whereTerm('key',value)->first();
$builder->whereIn('key',[value1,value2])->first();

模糊(分词)查询

$builder->whereMatch('key',value)->first();

范围查询

$builder->whereBetween('key',[value1,value2])->first();

复合查询

//SQL:select ... where (key=1 or key=2) and key1=1

$result = $builder->where(function (Builder $Query) {
    $Query->whereTerm('key',1)->orWhereTerm('key',2)
})->whereTerm('key1',1)->get();

分页

offset / limit

$builder->limit(10)->get(); 
$builder->offset(10)->limit(10)->get(); 

paginate

public function paginate(int $page, int $perPage = 15): Collection

scroll

public function scroll(string $scroll): self

排序 / 聚合

排序 asc/desc

public function orderBy(string $field, $sort): self

聚合(待增强)

public function aggBy($field, $type): self

结果

获取全部

public function get(): Collection

获取第一条

public function first()

通过id获取(索引较多时会出现需要制定分片路由情况)

public function byId($id)

public function byIdOrFail($id): stdClass

chunk

public function chunk(callable $callback, $limit = 2000, $scroll = '10m')

count

public function delete($id)

日志

#但其实,开启 config/larasearch.php 
    'open_log' => true,
每次查询都会有记录

//开启日志
$builder->enableQueryLog();

//打印所有查询
dump($build->getQueryLog());

//最新查询日志
dump($build->getLastQueryLog());