php – 如何通过Laravel的Eloquent ORM中的数据透视表数据进行排序

在我的数据库中,我有:

>顶部表
>帖子表
> tops_has_posts表.

当我在tops表上检索顶部时,我还检索与顶部相关的帖子.
但是,如果我想按特定顺序检索这些帖子怎么办?
所以我在我的数据透视表tops_has_posts中添加了一个范围字段,我尝试使用Eloquent按结果排序,但它不起作用.

我试试这个:

$top->articles()->whereHas('articles',function($q) {
    $q->orderBy('range','ASC');
})->get()->toArray();

还有这个 :

$top->articles()->orderBy('range','ASC')->get()->toArray();

两人都是绝望的尝试.

先感谢您.

有两种方法 – 一种是指定table.field,另一种是使用Eloquent别名pivot_field如果你使用withPivot(‘field’):
// if you use withPivot
public function articles()
{
  return $this->belongsToMany('Article','tops_has_posts')->withPivot('range');
}

// then: (with not whereHas)
$top = Top::with(['articles' => function ($q) {
  $q->orderBy('pivot_range','asc');
}])->first(); // or get() or whatever

这将起作用,因为Eloquent将withPivot中提供的所有字段别名为pivot_field_name.

现在,通用解决方案:

$top = Top::with(['articles' => function ($q) {
  $q->orderBy('tops_has_posts.range','asc');
}])->first(); // or get() or whatever

// or:
$top = Top::first();
$articles = $top->articles()->orderBy('tops_has_posts.range','asc')->get();

这将订购相关的查询.

注意:不要以这种方式命名.帖子不一定是文章,我会使用一个或另一个名称,除非确实需要这个.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


laravel的dd函数不生效怎么办
看不懂laravel文档咋办
安装laravel框架出现command怎么办
Laravel开发API怎么使用事务
laravel怎么构建复杂查询条件
laravel如何实现防止被下载
为什么laravel比yii火
一些常见的Laravel定时任务不运行的问题
laravel用路由有什么好处
composer无法安装laravel怎么办
laravel现在还用吗
laravel怎么替换主键id
laravel的appurl有什么用
如何修改Laravel的报错输出形式
laravel怎么避免foreach查表
laravel怎样操作数据库
laravel怎么截取字符串
laravel 是国内的吗
laravel怎么设置请求头
浅析Laravel社区Redis组件报错的问题和解决方法