laravel collect sortby不生效_3分钟短文 | Laravel 根据关联模型条目数量排序,怎么做?...

本文探讨了在Laravel中根据关联模型数量进行排序的需求,提供了使用`sortBy`、`withCount`和左连接查询的解决方案。强调了在大数据量下,避免全量获取数据并使用集合排序,推荐使用`withCount`进行聚合查询以优化性能。
摘要由CSDN通过智能技术生成

引言

在laravel中我们使用模型操作数据库表,同时使用 hasOne belongTo hasMany 等关联关系模型 建立不同模型之间的关联。对于简单的查询操作这完全应付的来。

9bde663ea730a02d88edfb00d37ae687.png

可是现实的业务需求往往充满变数,今天我们就说一个需求, 根据关联模型的数量进行排序,应该如何写代码。

学习时间

我们用实例进行解释,首先是表结构,为了简化操作,只罗列出主要的字段。首先是 hackathons 表的两个字段:

  • id
  • name
  • begins
  • ends
  • description

然后是 user 表的字段:

  • id
  • name

还有一个关联表 hackathon_user 字段:

  • hackathons_id
  • user_id

好了,基础数据已经建立,接着我们使用laravel的模型操作数据库表。首先声明 Hackathons 模型:

class Hackathon extends Model 
{
    protected $fillable = ['name', 'begins', 'ends', 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值