下面是翻译自 Laravel-News 的一篇教程,总结了 Laravel 的对象关系映射框架(ORM)的几个小技巧。...增量和减少 如果你平时是这么做的: $article = Article::find($article_id); $article->read_count++; $article->save(); 那么你可以试试这样...: $article = Article::find($article_id); $article->increment('read_count'); 或者这样也是可以的: Article::find(...$article_id)->increment('read_count'); Article::find($article_id)->increment('read_count', 10); // +10...'Guest Author' ]); } 太长了,下一篇再续上 http://blog.kbiao.me/2019/01/05/20-Laravel-Eloquent-Tips-and-Tricks
); }); Route::get('model/test/info', function () { $id = (int)request()->get('id', 0); $info...// laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasRelationships.php public function belongsTo...然后通过 // laravel/framework/src/Illuminate/Database/Eloquent/Relations/BelongsTo.php public function addConstraints...然后就是调用 newBelongsTo() 方法生成一个 laravel/framework/src/Illuminate/Database/Eloquent/Relations/BelongsTo.php...Route::get('model/test/relationship', function () { $id = (int)request()->get('id', 0); $info
中文文档: http://laravel-china.org/docs/eloquent#relationships 下面我们开始一个一个地学习。...() { return $this->belongsTo('User', 'user_id', 'id'); } } 一对多关系 学会了前面使用一对一关系的基础方法,后面的几种关系就简单多了...如下: $accounts = User::find(10)->hasManyPays()->get(); 此时得到的 `$accounts` 即为 `Illuminate\Database\Eloquent...我们可以使用一个重要的特性,关系预载入:http://laravel-china.org/docs/eloquent#eager-loading 直接上代码: $users = User::with('...---- 至此,深入理解 Laravel Eloquent 系列文章到此结束。推荐继续了解 软删除 、转换成数组/JSON。 END
四、查询构建器Laravel框架中的Eloquent ORM提供了方便的查询构建器,用于构建复杂的查询语句。下面是一些常用的查询构建器方法。...join方法join方法用于关联查询,例如:$users = User::join('orders', 'users.id', '=', 'orders.user_id')->get();上述代码中,查询了用户和订单表中符合条件的所有记录...总结通过上述文档和示例,我们可以看出Laravel框架中的Eloquent ORM提供了便捷的对象关系映射功能,可以大大简化开发者的数据库操作。...Eloquent ORM提供了大量的方法来操作数据,包括增删改查等,具体可以参考官方文档。...关联关系的定义需要在对应的模型类中定义,例如一对一关联需要在hasOne和belongsTo方法中定义,一对多关联需要在hasMany和belongsTo方法中定义,多对多关联需要在belongsToMany
从Laravel 5.5+开始,加入了API Resources这个概念。...address | 字段类型我就不赘述了,其中country_id、province_id以及city_id这三个外键分别对应了国家、省份以及城市表中的id。...this- belongsTo(City::class); } } 在我们的控制器中,我们拉取出所有客户: <?...CustomerResource($customer); } 要了解更多关于API Resources的详情,请戳官网文档: https://laravel.com/docs/5.7/eloquent-resources...本文主要讲解了Laravel5.5+ 使用API Resources快速输出自定义JSON方法详解,更多关于Laravel框架的使用技巧请查看下面的相关链接
快速入门 更换表名 protected $table = 'my_flights'; 更换主键名称 protected $primaryKey = 'id'; 注意: Eloquent 默认主键字段是自增的整型数据...= App\Flight::where('active', 1)->count(); $max = App\Flight::where('active', 1)->max('price'); 插入记录...外键 // User : id 父模型主键 return $this->belongsTo('App\User', 'user_id', 'id');...外键 // Post : id 父模型主键 return $this->belongsTo('App\Post', 'post_id', 'id');...例如, 你可能想要使用 Laravel 加密器对存储在数据库中的数据进行加密, 并且在 Eloquent 模型中访问时自动进行解密.
默认情况下,Laravel会假设你在用户模型中定义了 passport_id ,因为你试图创建与 passport 模型的关联。创建迁移文件时也请注意这一点!...我们可以使用 belongsTo 方法来实现这一点。 <?...user() { return $this- belongsTo(App\User::class); } } 一对多 你可以在 Laravel 中定义的下一个关联是一对多关联。...这就是定义这种关联所需的数据库表: suppliers: - idproducts: - id - supplier_idproduct_history: - id - product_id 即使 product_history...('passport')- get(); // 找到拥有 5 个及以上产品的发票 $invoices = App\Invoice::has('products', ' =', 5)- get(); 希望这篇文章能让你对
说明:本文主要说明Laravel Eloquent的延迟预加载(Eager Loading),使用延迟预加载来减少MySQL查询次数。同时,会将开发过程中的一些截图和代码黏上去,提高阅读效率。...*/ class Phone extends Model { /** * @return \Illuminate\Database\Eloquent\Relations\BelongsTo...*/ class Product extends Model { /** * @return \Illuminate\Database\Eloquent\Relations\BelongsTo...*/ public function shop() { return $this->belongsTo(Shop::class, 'shop_id');...*/ class Shop extends Model { /** * @return \Illuminate\Database\Eloquent\Relations\BelongsTo
->where('id','>',1)->select('content')->get(); 辅助查询案例,跳过n行取m行 where->skip(n)->take(m)->get(); 简单更新 更新前先查询...(); dump($res); } 动态作用域 Laravel中Eloquent还支持动态作用域,动态作用域指在查询过程中动态设置预置过滤器的查询条件,动态作用域与本地作用域类似...使用渴求式加载,即根据预先需求查询出所有数据 为了验证[渴求式加载]的好处,举下列例子 这里用到了Laravel Debugbar 调试 安装方法可参照我的另一个博客 - - - Laravel..." => 2 "countrie_count" => 1 "phone_count" => 2 ] 你还可以为关联数据计数字段取别名,可在同一次关联上多次计数..." => 2 "phone_count" => 2 "p_num" => 1 ] 渴求式加载 插入&更新关联模型 Eloquent提供了便捷的方法将新的模型增加至关联中
); $article->increment('read_count'); 也可以这些做: Article::find($article_id)->increment('read_count'); Article...::find($article_id)->increment('read_count', 10); // +10 Product::find($produce_id)->decrement('...'' }} 但你可以在Eloquent关系层面上做到这一点: public function author() { return $this->belongsTo('App\Author')->..., 100)', [200]) ->get(); // havingRaw Product::groupBy('category_id')->havingRaw(...'COUNT(*) > 1')->get(); // orderByRaw User::where('created_at', '>', '2018-11-11') ->
按照Laravel设定好的模式来写关联模型每个人都能写出高效和优雅的代码 (这点我认为适用于所有的Laravel特性)。...WHERE role_user.user_id = 1 远层一对多 Laravel还提供了远层一对多关联,提供了方便、简短的方式通过中间的关联来获得远层的关联。...shouldSelect($columns) )->getModels(); $this->hydratePivotRelation($models); if (count...func_get_args() : $relations ); } } //Eloquent Builder class Builder { public function...columns = ['*']) { $builder = $this->applyScopes(); //获取模型时会去加载要预加载的关联模型 if (count
据官方文档的说明,使用Eloquent ORM,插数据库的时候可以自动生成created_at,updated_at,代码如下: Model里的代码: <?...php namespace App\Models; use Illuminate\Database\Eloquent\Model; class Notice extends Model { protected...','from','id'); } public function toDep(){ return $this- belongsTo('App\Models\Department','...to','id'); } public function toUser(){ return $this- belongsTo('App\User','create_user','id'...原因分析:原生的插入语句,Laravel是不会自动帮你插入created_at和updated_at字段的。
Php Laravel框架 多表关系处理 之 Eloquent一对多关系处理 本博文主要介绍 Laravel 框架中 Eloquent 对一对多关系的处理以及在 Laravel Administrator...Eloquent 使得管理和处理这些关系变得简单。...php /** * scoreinfo:分数信息表 Model * so_id :主键自增 * s_id :学生信息表(stuinfo)主键 * soc_id :课程信息表(sobjectinfo...有主外键关系 * 而且是一对多的关系 */ public function StuInfo(){ return $this -> belongsTo...SobjectInfo(){ return $this -> belongsTo('SobjectInfo','soc_id'); } } ?
前言 众所周知Laravel是一套简洁、优雅的PHP Web开发框架(PHP Web Framework)。...下面这篇文章主要给大家总结了一些Laravel不经常用的小技巧,下面话不多说了,来一起看看详细的介绍吧 1....belongs to. */ public function post() { return $this- belongsTo('App\Post'); } } 2....懒加载指定字段 $posts = App\Post::with('comment:id,name')- get(); 3....Eloquent时间方法 $posts = Post::whereDate('created_at', '2018-01-31')- get(); $posts = Post::whereMonth
Eloquent Eloquent是laravel中的orm,采取的是active record的设计模式,里面的对象不仅包括领域逻辑,还包括了数据库操作,但是大家平时使用的时候可能没有探究eloquent...User::with('phone')->get()的时候,就会去eager load进phone了,具体的过程中,在调用Eloquent\Builder的get的时候,里面有个逻辑是: if (count...post that owns the comment. */ public function post() { return $this->belongsTo...():新增 user_id = 查询的表是role,join表user_role 在get的时候,其逻辑和HasOne等关系也所有不同,代码如下: // class belongsToMany public...($models); if (count($models) > 0) { $models = $this->query->eagerLoadRelations($models);
今天给大家介绍的是在 Laravel 中使用 Trait 优化代码结构,说起 Trait ,我一开始不知道是什么样的存在,有个模糊的印象是:复用。...\auth()->id(); }); } /** * @return \Illuminate\Database\Eloquent\Relations\BelongsTo...*/ public function creator() { return $this->belongsTo(User::class, 'creator_id')->...** * @return \Illuminate\Database\Eloquent\Relations\BelongsTo */ public function user()...结束语 就简单的给大家介绍一下 Trait 在 Laravel 中如何使用的,写的不对的地方和补充欢迎大家留言噢,哈哈。
'); })->get(); 底层执行的 SQL 查询语句如下: 如果你想进一步过滤出文章标题和评论都包含「Laravel学院」的用户,可以在上述闭包函数中通过查询构建器进一步指定: $users...', Post::class) ->whereNull('deleted_at'); }); })->get(); 如果你想过滤文章标题或评论都包含「Laravel...('content', 'like', 'Laravel学院%'); })->get(); 无结果过滤 与 has/orHas 方法相对的,还有一对 doesntHave/orDoesntHave 方法...Eloquent 允许我们为这种空对象定义一个默认的类型,这个对象的类型可以在定义关联关系的时候指定: public function author() { return $this->belongsTo...App\User 实例,你还可以为这个对象指定默认属性值: public function author() { return $this->belongsTo(User::class, 'user_id
说明:本文主要聊一聊Laravel测试数据填充器Seeder的小技巧,同时介绍下Laravel开发插件三件套,这三个插件挺好用哦。同时,会将开发过程中的一些截图和代码黏上去,提高阅读效率。...1、barryvdh/laravel-debugbar composer require barryvdh/laravel-debugbar --dev 2、barryvdh/laravel-ide-helper...评论次数 * @property integer $view_count 浏览次数 * @property integer $favorite_count 点赞次数 * @property boolean...' => $faker->randomNumber() , 'view_count' => $faker->randomNumber() , 'favorite_count...call(UsersTableSeeder::class); $this->call(CategoryTableSeeder::class); } 在路由文件中写上: Route::get
您在此之前可能就已经缓存过模型数据,但是我将向您展示一个使用动态记录模型的更精细的Laravel模型缓存技术,这是我一开始在RailsCasts学习到的技术。...这是这个技术的要点: 假设你有很多个 Comment 的Article模型,给定下面的Laravel blade 模板,你就可以像下面这样访问/article/:id路由时得到评论的数量: <h3 $article...碰巧 Eloquent 模型中有一个属性就叫$touches 。下面是我们的评论模型的大概样子: <?...guarded = []; protected $touches = ['article']; public function article() { return $this- belongsTo...guarded = []; protected $touches = ['article']; public function article() { return $this- belongsTo
引言 今天我们来说一下laravel框架里最常用的数据库模型操作,特别是功能复杂的应用程序, 往往会拆分出许多的业务表,关联表,在时间和空间上进行权衡。 ?...','articles.body','users.username', 'category.name') ->get(); 但是这样写组装的SQL语句太复杂了。...而且一点也不laravel。所以我们尝试着使用laravel eloquent orm 方式实现。 首先是创建表对应的模型 User.php, <?...Model{ protected $table = 'articles'; public function user() { return $this->belongsTo...(User::class, 'user_id', 'id'); } public function category() { return $this->belongsTo
领取专属 10元无门槛券
手把手带您无忧上云