模型 use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\SoftDeletes; class Flight...* * @return \Illuminate\Database\Eloquent\Builder */ public function scopePopular($query) { return...$query->where('votes', '>', 100); } /** * 只包含激活用户的查询作用域 * * @return \Illuminate\Database\Eloquent...* * @param \Illuminate\Database\Eloquent\Builder $query * @param mixed $type * @return \Illuminate...例如, 你可能想要使用 Laravel 加密器对存储在数据库中的数据进行加密, 并且在 Eloquent 模型中访问时自动进行解密.
说明:本文主要说明Laravel Eloquent的延迟预加载(Eager Loading),使用延迟预加载来减少MySQL查询次数。同时,会将开发过程中的一些截图和代码黏上去,提高阅读效率。...\Database\Eloquent\Collection|\App\Shop[] $shops * @method static \Illuminate\Database\Query\Builder...\Database\Eloquent\Collection|\App\Shop[] $shop * @method static \Illuminate\Database\Query\Builder|...\Database\Eloquent\Collection|\App\Merchant[] $merchant * @property-read \Illuminate\Database\Eloquent...\Collection|\App\Product[] $products * @method static \Illuminate\Database\Query\Builder|\App\Shop whereId
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 对象。
\Database\Eloquent\Collection|static[] */ public function all($columns = array('*')); /** *...\Database\Eloquent\Collection|static[] */ public function find($id, $columns = array('*'));.../** * @param $field * @param $value * @param array $columns * @return \Illuminate\Database\Eloquent\Collection...\Database\Eloquent\Collection|static[] */ public function find($id, $columns = array('*')) {...\Database\Eloquent\Collection|static[] */ public function findBy($field, $value, $columns = array
编写全局作用域 1.定义一个类 namespace App\Scopes; use Illuminate\Database\Eloquent\Scope; use Illuminate\Database...\Eloquent\Model; use Illuminate\Database\Eloquent\Builder; class AgeScope implements Scope { /**...* 将范围应用于给定的 Eloquent 查询生成器 * * @param \Illuminate\Database\Eloquent\Builder $builder...Eloquent 还能使用闭包定义全局作用域,如此一来,便就没必要定义一个单独的类了: namespace App; use Illuminate\Database\Eloquent\Model...中允许你自定义中间表模型,需要注意的是中间表模型与普通模型不一样 普通模型继承自Illuminate\Database\Eloquent\Model,而中间表模型继承自Illuminate\Database
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在功能拆分上相当灵活,其中查询返回的数据集,虽然继承了基类集合, 但是有一些特定的方法和用法。很多小白在写的时候,往往分不清到底是用的哪个类的哪个方法,导致凭空报错。...代码时间 laravel系统的基类就是 Illuminate\Support\Collection,同时提供了一个快捷助手函数collect 用于实例化一个集合类。...集合类可以调用系统提供的方法,非常灵活地操作数据。...虽然eloquent collection继承了基类Collection的特性,但是对于模型类的特性 有许多独特的方法。比如 modelKeys() 返回所有集合模型的primary key。...use Illuminate\Database\Eloquent\Collection;class OrderCollection extends Collection{ public function
laravel 的 Model 使用先进的 Eloquent ORM 但也有优缺点 优点是数据库的操作变的简单安全 缺点也明显数据库的操作变的缓慢笨重 Eloquent ORM 作为 laravel 中亮点...现在有了Model 接下来就是 调用他咯 调用 Model up 先创建一个新的控制器 TestMdlController在里面写个index方法 <?...php namespace App\Models; use Illuminate\Database\Eloquent\Model; class BaseModel extends...php namespace App\Models; use Illuminate\Database\Eloquent\Model; class Test extends BaseModel {...php namespace App\Models; use Illuminate\Database\Eloquent\Model; class Test extends BaseModel {
Laravel在模型事件中处理起来很方便:https://laravel-china.org/docs/laravel/5.5/eloquent#events Laravel 的模型事件有两种方式,...php namespace App; use Illuminate\Database\Eloquent\Model; class Log extends Model { protected...php use Illuminate\Support\Facades\Schema; use Illuminate\Database\Schema\Blueprint; use Illuminate\...(我这挺多的,之后大概长这样) 模型注册事件 然后我们触发一些事件(增删改,表的数据就有了) 事件 多对多的关联插入不会出触发模型(比如attach方法) 这时候就需要自己新建事件类来模拟...中的注入两个参数,一个是角色,另一个是attach或者detach返回的数组 PermissionRoleEvent 事件监听器PermissionRoleEventLog也继承基类LogBaseServer
根据单一责任开发原则来讲,在laravel的开发过程中每个表都应建立一个model对外服务和调用。...Illuminate\Database\Query\Builder 调用方法去完成整个SQL。...这个文件在你项目目录中的 vendor/laravel/framework/src/Illuminate/Database/Query 下,你可以自行去查看。...$parameters); } 转发,调用的是 Illuminate\Database\Connection ,用户处理 table()方法,随后会通过 table() 方法指向 Illuminate\...,首先每个 Eloquent ORM 都需要继承父类 Illuminate\Database\Eloquent\Model 你大概会这样写 User::find(1) 父类是不存在这个方法的,它会通过
Description 在Laravel中要想在数据库事务中运行一组操作,则可以在 DB facade 中使用 transaction 方法。如果在事务的闭包内抛出异常,事务将会被自动还原。...(); 注意: DB facade 的事务方法也可以用来控制 查询语句构造器 及 Eloquent ORM 的事务。...: 考点知识点关联表 wiki_tag_rel 现在要开启事务新增Wiki数据,新增wiki成功后再把它关联到指定的考点上去 (在laravel中使用查询构建器或者Eloquent ORM执行query...时,如果失败会返回 Illuminate\Database\QueryException 异常) attach方法来附加wiki和tag的关系(写入中间表) $newWiki->tags()->attach($tagIds);
前言 Laravel官方已经有scout+meilisearch 的一键扩展包 见:https://packagist.org/packages/laravel/scout 但是,肯定是不支持5.8版本的...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...return $models[$key]; } return null; })->filter(); } } 当然,其实就是调用方法...Scout 扩展中,我们可以通过在 AppServiceProvider 的 boot 方法中添加以下代码来实现: // 注册新的搜索引擎 resolve(EngineManager::class)-
软删除功能实际上就是利用了全局作用域功能 实现一个全局作用域功能只需要定义一个实现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方法将会被自动的调用 <?
尤其强调了利用 Resource::collection 方法简化数据提供过程,以及对比 Fractal 和 Laravel 的资源处理方式。...php artisan make:model Post -mf: 创建一个名为 "Post" 的 Eloquent 模型,并生成相应的迁移文件和工厂。...phpnamespace App;use Illuminate\Database\Eloquent\Model;class Post extends Model{protected $guarded =...($user->paginate());}静态collection方法将采用要转换的记录集合,并确保为每个记录实例化一个新的UsersResource。...总体而言,本文聚焦于利用 Laravel 中的 Resource::collection,并强调控制器对于处理数据关系包含的重要性。
php namespace App; use Illuminate\Database\Eloquent\Model; class Flight extends Model { /**...) ->take(10) ->get(); 可以看到,查询构造器的方法对模型类也是可以使用的 在eloquent ORM中,get和all方法查询出多个结果集,它们的返回值是一个Illuminate...\Database\Eloquent\Collection对象,该对象提供了多种对结果集操作的方法 public function find($key, $default = null); public...该对象的方法有很多,这里只列出一小部分,更多方法参考API文档 Collection 和使用说明文档。...php namespace App; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\SoftDeletes
,将对数据表的 SQL 执行转化为对模型类的方法调用。...在我们这里的博客应用项目中,可以通过 Composer 在根目录下运行如下命令下载对应的 Eloquent ORM 扩展包: composer require illuminate/database 为了能够正常使用...Eloquent 提供的模型事件功能,还可以下载 Laravel 提供的独立事件扩展包: composer require illuminate/events 上述扩展包下载完成后,就可以在博客项目根目录下的...进入 vendor/illuminate/database,可以通过阅读 README.md 文件查看如何使用独立的 Eloquent ORM 组件,接下来,我们将参照这个文档介绍来编写博客项目的模型类实现...,这里为了避免重构视图层代码,直接在查询结果上调用 toArray 方法将其转化为数组格式。
, 抛出异常 新建一个基础模型BaseModel, 其它所有模型继承这个模型, 并重写newEloquentBuilder方法 <?...php namespace App\Models; use Illuminate\Database\Eloquent\Model; class BaseModel extends Model {...php namespace App\Models\Database; use Illuminate\Database\Eloquent\Builder; use Illuminate\Database...\Eloquent\Collection; use Illuminate\Support\Facades\Log; use Illuminate\Support\Str; class MysqlCustomBuilder...try { return parent::get($columns); } catch (\Exception $e) { // 根据 laravel
引言 前两期为了说明laravel框架提供的数据库操作能力,直接使用DB门面操作, 而没有引入更为强大的eloquent orm功能。...创建一个模型类非常简单,只用继承系统的模型就可以了: use Illuminate\Database\Eloquent\Model; class Contact extends Model {} 因为遵循的是约定大于配置的惯例...上述方法会对Contact模型调用toArray方法进行格式化,然后返回一个 JsonResponse 对象的响应体。...Eloquent Collection,包含了Model模型的集合。...Illuminate\Database\Eloquent\Model; class Contact extends Model { // } 如果数据库表还没有创建,你想要把迁移文件的骨架代码也生成出来
grammar的compileCommand函数,此处我们调用的是compileCreate函数,至此我们就分析完了数据库表操作的方法,下面我们来看migrations功能。...本文最后讲下Eloquent中新增的对象之间的关系:多态关系,以下内容摘自[ Laravel 5.3 文档 ] Eloquent ORM —— 关联关系 表结构 多态关联允许一个模型在单个关联下属于多个不同模型...php namespace App; use Illuminate\Database\Eloquent\Model; class Comment extends Model { /**...*版本的时候,laravel/framework还采用的psr-0规范,所有其目录层级还是src/Illuminate/Database,在这个版本中有个新的目录Capsule,其下面是一个Manager...接着我们看第二个Making a Model,使用上非常简单: //User Model use Illuminate\Database\Eloquent\Model as Eloquent class
应用场景 某些SQL语句需要加某些共同的条件,例如status > 0,如果我们每条SQL语句都加的话显然是很麻烦的,作为一个优雅的框架,当然有相应的解决办法 编写作用域 Laravel 应用默认并没有为作用域预定义文件夹...,所以你可以按照自己的喜好在 app 目录下创建 Scopes目录并实现接口(Illuminate\Database\Eloquent\Scope)的方法apply。...php namespace App\Scopes; use Illuminate\Database\Eloquent\Scope; use Illuminate\Database...php namespace App\Models; use Illuminate\Database\Eloquent\Builder; use Illuminate\Database\...scope前缀,类似于修改器/访问器,并且可以一次性调用多个方法。
领取专属 10元无门槛券
手把手带您无忧上云