这次打算改造搜索能力,使用的是meilisearch,这是一个新出来的家伙,还不错! ?...,所以需要我们自己写一个基于scout的搜索插件。...php namespace App\Services; use App\Helper\MeiliSearch; use Illuminate\Database\Eloquent\Collection...; use Illuminate\Database\Eloquent\Model; use Illuminate\Support\Facades\Log; use Laravel\Scout\Builder...Scout 扩展中,我们可以通过在 AppServiceProvider 的 boot 方法中添加以下代码来实现: // 注册新的搜索引擎 resolve(EngineManager::class)-
Laravel 使用 Scout 实现全文检索 为何要采用全文检索 一个字块,可以秒级、毫秒级搜索出你搜索的内容 最原先我们可以简单的通过查询语句实现检索条件 比如: select * from table...即使你在数据库中添加了索引,还是不尽人意 因此需要一个更快、更快、更快的数据查询,而 Laravel 的 scout 就是专门为搜索来解决难题的 简介 Laravel Scout 为 Eloquent...通过使用模型观察者, Scout 会自动同步 Eloquent 记录的搜索索引。 目前, Scout 自带一个 Algolia 驱动。...php namespace App\Models; use Laravel\Scout\Searchable; use Illuminate\Database\Eloquent\Model; class...php namespace App\Models; use Laravel\Scout\Searchable; use Illuminate\Database\Eloquent\Model; class
Laravel scout 与 es 先安装 scout 包 composer require laravel/scout 再生成配置文件 php artisan vendor:publish --provider...="Laravel\Scout\ScoutServiceProvider" 在 config/app.php 的 provider 中,添加 Laravel\Scout\ScoutServiceProvider...php namespace App; use Illuminate\Database\Eloquent\Model; use Laravel\Scout\Searchable; class Article...Searchable 和重载 toSearchableArray 函数就可以了 然后使用命令 php artisan scout:import "App\Article" 将目前数据库中的数据,按照...toSearchableArray 的规则导入,导入完成就可以了 验证结果 es 和 scout 的步骤已经走完了,接下来就可以使用了 先定义 graphql 接口 searchArticles(keyWord
Laravel 官方开发组本周发布了 Laravel 6.11.0 版本,新版本在 Eloquent 模型查询时新增 firstWhere 方法,优化了基于 Redis 的多频道广播,以及一些现有版本的问题修复...1、新增功能 Eloquent firstWhere() 方法 Eloquent 模型现在支持调用 firstWhere 方法,它的功效和 where()->first() 一样,算是一个语法糖: /...'); 需要注意的是这个方法仅仅在 Eloquent 模型查询中可用,在数据库查询构建器中不可用。...新增特性 新增 Illuminate\Database\Eloquent\Builder::firstWhere() 方法 Redis 支持一次广播数据到多个频道 问题修复 修复 WithFaker:...:makeFaker() 中的未定义属性 修复 Str::afterLast() 方法 修复 PHP 7.3 插入浮点类型到 MySQL 数据库问题 修复通过自定义中间表属性名刷新模型问题 代码调整 在
根据单一责任开发原则来讲,在laravel的开发过程中每个表都应建立一个model对外服务和调用。...Illuminate\Database\Query\Builder 调用方法去完成整个SQL。...$parameters); } 转发,调用的是 Illuminate\Database\Connection ,用户处理 table()方法,随后会通过 table() 方法指向 Illuminate\...,首先每个 Eloquent ORM 都需要继承父类 Illuminate\Database\Eloquent\Model 你大概会这样写 User::find(1) 父类是不存在这个方法的,它会通过...new Builder($query); } 最后我们到了 Illuminate\Database\Eloquent\Builder 文件下,这个类中涵盖了ORM的基本操作,例如find , findOrFail
数据库管理相关的代码都放在Schema目录下, 最开始的结构如下: src/Illuminate/Database/Schema ├── Blueprint.php └── Builder.php 就两个文件...grammar的compileCommand函数,此处我们调用的是compileCreate函数,至此我们就分析完了数据库表操作的方法,下面我们来看migrations功能。...此处为什么会出现Manager,当项目变复杂后,我们很难简单的和Eloquent的内部的组件进行有效的功能了,这个时候需要一个项目的门面,帮助我们和外界沟通,让外界尽可能简单的使用Eloquent,于是就出现了...Manager,记得网上搜索过关键字Using Eloquent outside Laravel,我们可以看到一篇Vivek Kumar Bansal写的文章,文章从2方面介绍了怎么使用Eloquent...接着我们看第二个Making a Model,使用上非常简单: //User Model use Illuminate\Database\Eloquent\Model as Eloquent class
,所以你可以按照自己的喜好在 app 目录下创建 Scopes目录并实现接口(Illuminate\Database\Eloquent\Scope)的方法apply。...* * @param \Illuminate\Database\Eloquent\Builder $builder * @param \Illuminate\..."boot启动"方法中使用static::addGlobalScope(new 你的作用域类); <?...php namespace App\Models; use Illuminate\Database\Eloquent\Builder; use Illuminate\Database\...$builder->where('status','>', 1); }); } } 有些查询并不想使用作用域,可以通过调用以下方法移除作用域 ScopeTest::
说明:本文主要说明Laravel Eloquent的延迟预加载(Eager Loading),使用延迟预加载来减少MySQL查询次数。同时,会将开发过程中的一些截图和代码黏上去,提高阅读效率。...\Database\Eloquent\Collection|\App\Shop[] $shops * @method static \Illuminate\Database\Query\Builder...static \Illuminate\Database\Query\Builder|\App\Phone whereUpdatedAt($value) * @mixin \Eloquent */...\Database\Eloquent\Collection|\App\Shop[] $shop * @method static \Illuminate\Database\Query\Builder|...里关联方法是Merchant()和Products(),Merchant Model里关联方法是Phone() $shops = $this->shop->with(['merchant.phone
我们从软删除的使用,再顺便说一说模型内的作用域的概念。 代码时间 常规的删除操作分两步进行,一步是把数据从数据库中查询出来,使用laravel模型的方法, 则返回的是一个模型对象。...模型中相关代码如下: use Illuminate\Database\Eloquent\Model;use Illuminate\Database\Eloquent\SoftDeletes;class...\Database\Eloquent\Model;use Illuminate\Database\Eloquent\Builder;class ActiveScope implements Scope{...', true); }} 在模型 Contact 内调用: use App\Scopes\ActiveScope;use Illuminate\Database\Eloquent\Model;class...写在最后 本文从laravel模型的写操作删除动作,讲到了软删除的概念。进而引申出来本地作用域和全局作用域的使用。软删除几乎贯穿了我们应用的始终,需要大家勤学苦练。
软删除功能实际上就是利用了全局作用域功能 实现一个全局作用域功能只需要定义一个实现Illuminate\Database\Eloquent\Scope接口的类,该接口只有一个方法apply,在该方法中增加查询需要的约束...php namespace App\Scopes; use Illuminate\Database\Eloquent\Scope; use Illuminate\Database\Eloquent\...* * @param \Illuminate\Database\Eloquent\Builder $builder * @param \Illuminate\Database...Mutators 在Eloquent模型中,Accessor和Mutator可以用来对模型的属性进行处理,比如我们希望存储到表中的密码字段要经过加密才行,我们可以使用Laravel的加密工具自动的对它进行加密...假设我们有一个字段是first_name,当我们尝试去获取first_name的值的时候,getFirstNameAttribute方法将会被自动的调用 <?
laravel/framework/src/Illuminate/Database/Eloquent/Collection.php 对象,然后这个对象里面有个 items 属性,是一个数组。...laravel/framework/src/Illuminate/Collections/Collection.php 是集合类,里面的方法大部分都调用的是 laravel/framework/src/...在所有模型都要继承的 laravel/framework/src/Illuminate/Database/Eloquent/Model.php 类中,我们很快就能发现一个 query() 静态方法。...不过这里需要注意的是,模型默认生成的 QueryBuilder 是 llaravel/framework/src/Illuminate/Database/Eloquent/Builder.php 对象,...而不是我们之前 查询构造器 中的 laravel/framework/src/Illuminate/Database/Query/Builder.php 对象。
(Binput::except(['sort', 'order', 'per_page'])); components->sort( sort和search方法都不是Laravel自带的Model方法,...* * @param \Illuminate\Database\Eloquent\Builder $query * @param string...\Database\Eloquent\Builder */ public function scopeSort(Builder $query, $column, $direction)...* * @param \Illuminate\Database\Eloquent\Builder $query * @param array...$search * * @return \Illuminate\Database\Eloquent\Builder */ public function scopeSearch
说明:本文主要聊一聊Laravel测试数据填充器Seeder的小技巧,同时介绍下Laravel开发插件三件套,这三个插件挺好用哦。同时,会将开发过程中的一些截图和代码黏上去,提高阅读效率。...\Database\Eloquent\Collection|\App\Comment[] $comments * @property-read \Illuminate\Database\Eloquent...,在控制器里输入方法时会自动补全auto complete字段属性的方法: 2、mpociot/laravel-test-factory-helper 输入指令php artisan test-factory-helper...Laravel官方推荐使用模型工厂自动生成测试数据,推荐这么写的: //先输入指令生成database/seeds/CategoryTableSeeder.php文件: php artisan make...分享下最近发现的一张好图和一篇极赞的文章: 文章链接:Laravel的中大型專案架構
对于任何一个模型,如果需要使用软删除功能,需要在模型中使用 Illuminate\Database\Eloquent\SoftDeletes这个 trait。....已删除数据可以恢复 Model的软删除功能实现 Illuminate\Database\Eloquent\Model中delete方法源码: public function delete() {...Laravel中软删除数据的过滤也是使用这种方式实现的。...SoftDeletes trait中加入了Illuminate\Database\Eloquent\SoftDeletingScope全局的Scope。...但是有的时候,项目中会使用一个整形的字段标记数据是否删除。在这样的场景下,需要对Laravel的软删除进行修改才能够实现。
events WHERE `published` = 1; 如果条件 published = 1 在默认的情况下需要开启,我们可以使用laravel模型的 全局作用域 方式为所有查询追加上这个条件。...在模型文件 Event 内头部引入下述类: use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Builder...所以,本地作用域 应运而生,专门用于某个模型文件的方法,手动调用的时候就起作用,不调用就不会主动追加。...既然本地作用域返回的是 QueryBuilder 实例,那么自然就可以链式调用本地作用域的方法,和 QueryBuilder 的方法。...讲述了两个方法: 全局作用域:全局起作用,需要手动移除; 本地作用域:只有手动调用起作用,可链式使用; 这样的设计模式可以很大程度上节约查询代码,但是对于维护,需要同等熟悉的开发者彼此遵循开发规范,写出可维护的代码
,将对数据表的 SQL 执行转化为对模型类的方法调用。...ORM 两种最常见的实现方式是 Active Record 和 Data Mapper,Active Record 尤其流行,在很多框架中都能看到它的身影,比如 Laravel 框架使用的 Eloquent...在我们这里的博客应用项目中,可以通过 Composer 在根目录下运行如下命令下载对应的 Eloquent ORM 扩展包: composer require illuminate/database 为了能够正常使用...进入 vendor/illuminate/database,可以通过阅读 README.md 文件查看如何使用独立的 Eloquent ORM 组件,接下来,我们将参照这个文档介绍来编写博客项目的模型类实现...Post.php 和 Album.php 中,它们继承了 Eloquent ORM 的模型类基类 Model,这样就可以使用 Eloquent 模型类支持的属性和方法。
说明:本文主要学习下Query Builder编译Fluent Api为SQL的细节和执行SQL的过程。...实际上,上一篇聊到了\Illuminate\Database\Query\Builder这个非常重要的类,这个类含有三个主要的武器:MySqlConnection, MySqlGrammar, MySqlProcessor...$this->compileUnions($query); } return $sql; } 这里首先会调用Illuminate\Database\Query\...OK, illuminate/database package不仅提供了Query Builder,还提供了Eloquent ORM。...以后再聊Eloquent ORM的实现原理吧。 总结:本文主要学习了Query Builder编译SQL细节和执行SQL逻辑。后续在分享下Eloquent ORM的实现原理,到时见。
通过全局作用域类实现 要实现「全局作用域」,首先需要编写一个实现 Illuminate\Database\Eloquent\Scope 接口的全局作用域类,这里我们将其命名为 EmailVerifiedAtScope...php namespace App\Scopes; use Illuminate\Database\Eloquent\Builder; use Illuminate\Database\Eloquent...\Model; use Illuminate\Database\Eloquent\Scope; class EmailVerifiedAtScope implements Scope { public...推荐使用这种方式来构建需要在多个场景调用的复杂 Eloquent 查询。 移除局部作用域很简单,不要在查询中指定对应的过滤器方法即可。...`deleted_at` is null 动态作用域的调用和移除方式和局部作用域一样。 本系列教程首发在Laravel学院(laravelacademy.org)
引言 laravel在功能拆分上相当灵活,其中查询返回的数据集,虽然继承了基类集合, 但是有一些特定的方法和用法。很多小白在写的时候,往往分不清到底是用的哪个类的哪个方法,导致凭空报错。...代码时间 laravel系统的基类就是 Illuminate\Support\Collection,同时提供了一个快捷助手函数collect 用于实例化一个集合类。...集合类可以调用系统提供的方法,非常灵活地操作数据。...我们手动创建一个eloquent collection 用于操作query builder返回的数据集合。...use Illuminate\Database\Eloquent\Collection;class OrderCollection extends Collection{ public function
说明:本文主要学习Laravel Database模块的Query Builder源码。...在看下Query Builder源码之前,先大概探索下illuminate/database package的目录结构。...,是主要的组件之一,用来CRUD时链接对应的DB Console 该文件内包含migration和seed的命令,如php artisan db:seed, php artisan migrate Eloquent...该文件夹内包含的就是Eloquent的主要实现类,如重点的Model类,Builder类,Relations子文件夹内包含的表的关系类。...类,还包括Grammars和Processors两大类别,根据四个不同的DB分门别类 Schema 是设计database的主要参与类,主要的类是Builder类和Blueprint类,还有Grammars
领取专属 10元无门槛券
手把手带您无忧上云