[ Laravel 5.3 文档 ] 官方包 —— Laravel Scout

   2016-10-17 0
核心提示:1、简介LaravelScout为Eloquent模型全文搜索实现提供了简单的、基于驱动的解决方案,通过使用模型观察者,Scout会自动同步更新模型记录的索引。目前,Scout通过Algolia驱动提供搜索功能,不过,编写自定义驱动很简单,你可以很轻松地通过自己的搜索实现来扩展

1、简介

Laravel ScoutEloquent模型 全文搜索实现提供了简单的、基于驱动的解决方案,通过使用模型观察者,Scout会自动同步更新模型记录的索引。

目前,Scout通过 Algolia 驱动提供搜索功能,不过,编写自定义驱动很简单,你可以很轻松地通过自己的搜索实现来扩展Scout。

2、安装

首先,我们通过Composer包管理器来安装Scout:

composer require laravel/scout

接下来,需要添加 ScoutServiceProvider 到配置文件 config/app.phpproviders 数组:

Laravel\Scout\ScoutServiceProvider::class,

注册Scout服务提供者之后,还需要通过Artisan命令 vendor:publish 发布Scout配置,该命令会发布配置文件 scout.phpconfig 目录:

php artisan vendor:publish --provider="Laravel\Scout\ScoutServiceProvider"

最后,如果你想要模型变得可搜索,需要添加 Laravel\Scout\Searchable trait到模型类,该trait会注册模型观察者来保持搜索驱动与模型记录数据的一致性:

<?php

namespace App;

use Laravel\Scout\Searchable;
use Illuminate\Database\Eloquent\Model;

class Post extends Model
{
    use Searchable;
}

队列

尽管不强制使用Scout,不过在使用这个库之前强烈建议考虑配置一个队列驱动。运行一个队列进程将允许Scout把所有同步模型信息到搜索索引的操作推送到队列中,从而为应用的web界面提供更快的响应时间。

配置好队列驱动后,在配置文件 config/scout.php 中设置 queue 选项的值为 true

'queue' => true,

驱动预备知识

Algolia

使用Algolia驱动的话,需要在配置文件 config/scout.php 中设置Algolia的 idsecret 信息。配置好之后,还需要通过Composer包管理器安装Algolia PHP SDK:

composer require algolia/algoliasearch-client-php

3、配置

配置模型索引

每个Eloquent模型都是通过给定的搜索“索引”进行同步,该索引包含了所有可搜索的模型记录,换句话说,你可以将索引看作是一个MySQL数据表。默认情况下,每个模型都会被持久化到与模型对应表名(通常是模型名称的复数形式)相匹配的索引中,不过,你可以通过重写模型中的 searchableAs 方法来覆盖这一默认设置:

<?php

namespace App;

use Laravel\Scout\Searchable;
use Illuminate\Database\Eloquent\Model;

class Post extends Model
{
    use Searchable;

    /**
     * 获取模型的索引名称.
     *
     * @return string
     */
    public function searchableAs()
    {
        return 'posts_index';
    }
}

配置搜索数据

默认情况下,模型以完整的 toArray 格式持久化到搜索索引,如果你想要自定义被持久化到搜索索引的数据,可以重写模型上的 toSearchableArray 方法:

<?php

namespace App;

use Laravel\Scout\Searchable;
use Illuminate\Database\Eloquent\Model;

class Post extends Model
{
    use Searchable;

    /**
     * 获取模型的索引数据数组
     *
     * @return array
     */
    public function toSearchableArray()
    {
        $array = $this->toArray();

        // 自定义数组...

        return $array;
    }
}

4、索引

批量导入

如果你想要安装Scout到已存在的项目,你可能已经有了想要导入搜索驱动的数据库记录,Scout提供了Artisan命令 import 用于导入所有已存在的数据到搜索索引:

php artisan scout:import "App\Post"

添加记录

添加 Laravel\Scout\Searchable trait到模型之后,剩下需要做的就是保存模型实例,然后该实例会自动被添加到模型索引,如果你配置了Scout使用队列,该操作会被推送到队列在后台执行:

$order = new App\Order;

// ...

$order->save();

通过查询添加

如果你想要通过Eloquent查询添加模型集合到搜索索引,可以在Eloquent查询之后追加 searchable 方法调用。 searchable 方法会分组块进行查询并将结果添加到搜索索引。再次强调,如果你配置了Scout使用队列,所有的组块查询会被推送到队列在后台进行:

// 通过Eloquent查询添加...
App\Order::where('price', '>', 100)->searchable();

// 还可以通过关联关系添加记录...
$user->orders()->searchable();

// 还可以通过集合添加记录...
$orders->searchable();

searchable 方法还可以进行“upsort”操作,换句话说,如果模型记录已经存在于索引,则会被更新,如果不存在,则会被添加。

更新记录

要更新可搜索的模型,需要更新模型实例的属性并保存模型到数据库。Scout会自动持久化更新到搜索索引:

$order = App\Order::find(1);

// 更新订单...

$order->save();

还可以使用模型查询提供的 searchable 方法更新模型集合,如果模型在搜索索引中不存在,则会被创建:

// 通过Eloquent查询更新...
App\Order::where('price', '>', 100)->searchable();

// 还可以通过关联关系更新...
$user->orders()->searchable();

// 还可以通过集合更新...
$orders->searchable();

移除记录

要从索引中移除记录,只需从数据库中删除记录即可,这种移除方式甚至兼容软删除模型:

$order = App\Order::find(1);

$order->delete();

如果你在删除记录前不想获取模型,可以使用模型查询实例或集合上的 unsearchable 方法:

// 通过Eloquent查询移除...
App\Order::where('price', '>', 100)->unsearchable();

// 还可以通过关联关系移除...
$user->orders()->unsearchable();

// 还可以通过集合移除...
$orders->unsearchable();

暂停索引

有时候你需要在不同步模型数据到搜索索引的情况下执行批量的Eloquent操作,可以通过 withoutSyncingToSearch 方法来实现。该方法接收一个立即被执行的回调,该回调中出现的所有模型操作都不会同步到搜索索引:

App\Order::withoutSyncingToSearch(function () {
    // Perform model actions...
});

5、搜索

你可以通过 search 方法来搜索一个模型,该方法接收一个用于搜索模型的字符串,然后你还需要在这个搜索查询上调用一个 get 方法来获取与给定搜索查询相匹配的Eloquent模型:

$orders = App\Order::search('Star Trek')->get();

由于Scout搜索返回的是Eloquent模型集合,你甚至可以直接从路由或控制器中返回结果,它们将会被自动转换为JSON格式:

use Illuminate\Http\Request;

Route::get('/search', function (Request $request) {
    return App\Order::search($request->search)->get();
});

where子句

Scout允许你添加简单的where子句到搜索查询,目前,这些子句仅支持简单的数值相等检查,由于搜索索引不是关系型数据库,更多高级的where子句暂不支持:

$orders = App\Order::search('Star Trek')->where('user_id', 1)->get();

分页

除了获取模型集合之外,还可以使用 paginate 方法对搜索结果进行分页,该方法返回一个 Paginator 实例 —— 就像你 对传统Eloquent查询进行分页 一样:

$orders = App\Order::search('Star Trek')->paginate();

你可以通过传入数量作为 paginate 方法的第一个参数来指定每页显示多少个模型:

$orders = App\Order::search('Star Trek')->paginate(15);

获取结果之后,可以使用Blade显示结果并渲染分页链接,就像对传统Eloquent查询进行分页时一样:

<div class="container">
    @foreach ($orders as $order)
        {{ $order->price }}
    @endforeach
</div>

{{ $orders->links() }}

6、自定义引擎

编写引擎

如果某个内置的Scout搜索引擎不满足你的需求,可以编写自定义的引擎并将其注册到Scout,自定义的引擎需要继承自抽象类 Laravel\Scout\Engines\Engine ,该抽象类包含了5个自定义引擎必须实现的方法:

use Laravel\Scout\Builder;

abstract public function update($models);
abstract public function delete($models);
abstract public function search(Builder $builder);
abstract public function paginate(Builder $builder, $perPage, $page);
abstract public function map($results, $model);

这5个方法的实现可以参考 Laravel\Scout\Engines\AlgoliaEngine 类,这个类为我们学习如何在自定义引擎中实现这些方法提供了最佳范本。

注册引擎

编写好自定义引擎之后,可以通过Scout引擎管理器提供的 extend 方法将其注册到Scout。你需要在 AppServiceProvider (或者其他服务提供者)的 boot 方法中调用这个 extend 方法。例如,如果你编写了 MySqlSearchEngine ,可以这样注册:

use Laravel\Scout\EngineManager;

/**
 * 启动任意应用服务.
 *
 * @return void
 */
public function boot()
{
    resolve(EngineManager::class)->extend('mysql', function () {
        return new MySqlSearchEngine;
    });
}

引擎被注册之后,可以在配置文件 config/scout.php 中将其设置为Scout默认的驱动:

'driver' => 'mysql',
 
标签: Laravel
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • nginx 各类网站设置 (laravel , thinkphp , nod
    基础部分设置[root@centos ~]# vim /opt/nginx/conf/nginx.confuser www www;worker_processes auto;pid logs/nginx.pid;worker_rlimit_nofile 100000;events {use epoll;multi_accept on;worker_connections 65535 ;}http {include mime.types;default_type
    02-09
  • PHP trait 特性在 Laravel 中的使用个人心得
    trait 是在PHP5.4中为了方便代码复用的一种实现方式,但目前我在看的的PHP项目中较少看的有程序员去主动使用这个实现方式,在laravel中有很多 trait 的使用,关于trait 在 laravel 的使用请参看 Laravel 在哪些地方用了 trait?我曾在 Laravel 中大型项目面向
    02-09
  • 让我们用 laravel-mix 为 TypeScript 和 Sass
    介绍前端编译TypeScript、Sass、模板引擎等时经常用到Gulp和webpack。这是我个人的印象,但它们似乎都难以管理,因为它们的描述往往复杂而冗长。我不想积极进行,因为我要担心加载器的顺序并且有很多配置选项,我必须花时间去了解它们。我想推荐那里laravel
  • PHP Laravel软删除的实现方法介绍
    用Laravel 自带的 Eloquent ORM 来实现软删除。首先在数据迁移文件中添加删除时间字段./database/migrations/2014_10_12_000000_create_users_table.php?phpuse Illuminate\Database\Migrations\Migration;use Illuminate\Database\Schema\Blueprint;use Illu
  • Laravel中如何使用PHP的装饰器模式 php laravel
    本文小编为大家详细介绍“Laravel中如何使用PHP的装饰器模式”,内容详细,步骤清晰,细节处理妥当,希望这篇“Laravel中如何使用PHP的装饰器模式”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。装饰器模式定义:它可以帮助您在
    02-08 laravelphp
  • PHP laravel使用自定义邮件类实现发送邮件
    PHP laravel使用自定义邮件类实现发送邮件
    当登录邮箱为腾讯企业邮箱的时候。Phpmailer发送邮件就不好用了,具体哪里不好用,我没真没找到。但是,邮件得发啊,怎么办呢?我这里搞了一个自定义的发送邮件类,腾讯企业邮箱也可用。但是,邮件发送失败,不会返回报错信息,这个可能是有点坑。源码如下:?
  • 详解PHP laravel中的加密与解密函数
    目录一:简介二:配置三:使用加密/解密1:加密2:不使用序列化进行加密3:解密Laravel为我们提供了完整的加密方法及加密模式。我之前一般在加密的时候使用的是我自己写的加密函数,但是这个玩意,有的位置还是不太使用,当然,破解的话,基本上也是不可能的
  • PHP laravel缓存cache机制详解
    目录一、访问多个缓存存储二、从缓存中获取数据1.获取数据并设置默认值2.检查缓存项是否存在3.数值增加/减少4.获取存储5.获取删除三、缓存中存储数据1.获取存储数据2.缓存不存在时存储数据3.永久存储数据四、从缓存中移除数据Laravel中的cache为我们提供了三
  • PHP laravel实现导出PDF功能
    PHP laravel实现导出PDF功能
    目录一、laravel-tcpdf二、tcpdf三、TCPDF解决保存中文文件名的方法补充一、laravel-tcpdf导出PDF文件Laravel框架为我们集成了一个插件tcpdf。下载地址:https://github.com/elibyy/tcpdf-laravel然后使用composer进行安装就可以了。具体安装过程,请查看文末
  • PHP laravel缓存cache机制怎么实现
    今天小编给大家分享一下PHP laravel缓存cache机制怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Laravel中的cache为我们
点击排行