【问题标题】:Selecting ten top categories based on a columnt in another table with eloquent雄辩的根据另一个表中的列选择十个顶级类别
【发布时间】:2018-05-31 22:37:12
【问题描述】:

我有三个表:uploadscategories 和一个名为 category_uploadmany-to-many 表。

表格如下所示:

**categories**

id
name

**uploads**

id
name
downloads(integer)

**category_upload**

id
category_id
upload_id

每次我下载“上传”时,下载列中的值都会增加 1。

我想做但不知道如何开始是根据uploads 表中的downloads 列选择前10 个类别。因此,如果downloads 列的总和是来自给定类别的所有上传的最大列,则该类别应该排在第一位,依此类推到第十位。

这可以通过 eloquent 还是仅使用 SQL 来实现?如何实现?任何提示表示赞赏!

这是我在模型中建立关系的方式:

类别:

public function uploads(){
        return $this->belongsToMany('App\Upload');
    } 

上传:

public function category(){
    return $this->belongsToMany('App\Category');
}

【问题讨论】:

  • 样本数据和期望的结果真的很有帮助。例如,什么是“书”?
  • @GordonLinoff 书是上传的,我更正了。

标签: php mysql sql laravel eloquent


【解决方案1】:
Select category_id, uploads
From (
    Select category_id, SUM(downloads) as uploads
    From uploads as u
    Left join upload_category as uc on uc.id=u.upload_id
    Left join category as c on c.id=uc.category_id
    Group by  category_id    )as t
  Order by uploads desc
  Limit 10

【讨论】:

  • 您好,感谢您的回答。它进行了一些小的调整,这是我更改的内容: 选择名称,上传自(选择 c.name,SUM(下载)作为上传从上传作为 u INNER join category_upload as uc on uc.upload_id=u.id INNER join categories as c on c.id=uc.category_id Group by c.name )as t Order by uploads desc Limit 10
【解决方案2】:

你的Category 模型

public function downloads()
{
    return $this->hasMany('App\Upload','category_upload','category_id','upload_id');
}

在你的控制器中(Catagory)

试试这个

Category::select("*")->with(['downloads' => function($q){
    $q->oderBy('downloades','desc')->take(10)->get();
})

【讨论】:

    猜你喜欢
    • 2015-09-28
    • 2015-09-25
    • 1970-01-01
    • 1970-01-01
    • 2018-06-27
    • 1970-01-01
    • 2020-02-16
    • 2012-01-30
    • 2015-02-15
    相关资源
    最近更新 更多