假设有如下模型关系:
Tutorial -> (hasMany) Chapters -> (hasMany) videos
我想在 Tutorial 模型中使用 withCount 统计 videos 的数量要怎么实现?
解决办法:
方法1:通过远程一对多关联关系统计。
模型定义如下关系:
class Tutorial extends Model
{
function chapters()
{
return $this->hasMany(Chapter::class);
}
function videos()
{
return $this->hasManyThrough(Video::class, Chapter::class);
}
}
调用:
Tutorial::withCount(['videos']);
方法2:通过闭包函数方式
Tutorial::with(['chapters' => function($query){
$query->withCount('videos');
}])
->get();
想要了解更多内容,请持续关注码农资源网,一起探索发现编程世界的无限可能!
本站部分资源来源于网络,仅限用于学习和研究目的,请勿用于其他用途。
如有侵权请发送邮件至1943759704@qq.com删除
码农资源网 » Laravel 中 withCount 统计嵌套关联数据
本站部分资源来源于网络,仅限用于学习和研究目的,请勿用于其他用途。
如有侵权请发送邮件至1943759704@qq.com删除
码农资源网 » Laravel 中 withCount 统计嵌套关联数据