为了账号安全,请及时绑定邮箱和手机立即绑定

在 Laravel 中的 with() 之后的另一个模型中的 OrderBy

在 Laravel 中的 with() 之后的另一个模型中的 OrderBy

PHP
慕工程0101907 2022-11-12 13:24:45
我有一个问题,我正在尝试按链接表中的日期对请求进行排序。我在一对多中有一个名为 User 的表和另一个名为 Posts 的表。User::with('posts')    ->where('last_name', 'like', $search['lastname'] . '%')    ->where('first_name', 'like', $search['firstname'] . '%')    ->where('email', 'like', '%' . $search['email'] . '%')    ->whereHas('posts', function ($query) use ($search) {        $query->where('reference', 'like', $search['reference'] . '%')            ->orderBy('date', 'asc');    })    ->orderBy('posts.date', 'desc')    ->paginate(15);我怎样才能做到这一点 ?
查看完整描述

2 回答

?
慕虎7371278

TA贡献1802条经验 获得超4个赞

目前用户是主要实体,因此帖子的排序将在该用户的帖子中进行,而不是在所有帖子中全局排序。我猜您想进行全局排序,这意味着帖子应该按日期排序


试试这个在用户类中添加一个新关系


class User extends Model {

  public function rpost() {

    return $this->belongsTo(\where\ever\posts::class, 'user_id', 'id');

    //inverse mapping from user --> posts table

    //assuming posts table is using user_id column to track the ownership

    //and user table has id as it's primary key

  }

}

然后修改你的代码


User::with('rpost')

    ->select('posts.title'.'posts.id', 'users.name',  

           \DB::raw('(SELECT posts.date FROM posts WHERE user.id = posts.user_id ) as sort'))

    ->where('last_name', 'like', $search['lastname'] . '%')

    ->where('first_name', 'like', $search['firstname'] . '%')

    ->where('email', 'like', '%' . $search['email'] . '%')

    ->whereHas('posts', function ($query) use ($search) {

        $query->where('reference', 'like', $search['reference'] . '%');

    })

    ->orderBy('sort')

    ->paginate(15);


查看完整回答
反对 回复 2022-11-12
?
智慧大石

TA贡献1946条经验 获得超3个赞

您可以使用 sortBy


 $users = User::with('posts')->get()

  ->sortBy(function($user) { 

     return $user->posts->created_at;

  })

或者您可以将这样的连接与 orderBy 一起使用


  $query = User::where('last_name', 'like', $search['lastname'] . '%')->where(

        'first_name',

        'like',

        $search['firstname'] . '%'

    )->where('customers.email', 'like', '%' . $search['email'] . '%');

    $query = $query->join('posts', 'posts.user_id','=','users.id');

    $query = $query->select('posts*','users.*');

    $query = $query->orderBy('posts.created_at','asc');

    $record = $query->get();


查看完整回答
反对 回复 2022-11-12
  • 2 回答
  • 0 关注
  • 349 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号