duanmei1946 2017-01-14 18:42
浏览 14
已采纳

Laravel从急切的负载中获得一个值

I've got this query in Laravel that's returning all forums with some extra information:

return Forum::with(['messages.user' => function($query){
    $query->select('id', 'name');
}])->withCount('messages')->paginate(10);

but now it eager loads all related messages as well but I only need the author from a message. How could I get this result?

  • 写回答

3条回答 默认 最新

  • dongyuandou2521 2017-01-14 19:40
    关注

    Assuming the table you have for your Message model is messages and that it has the columns forum_id and user_id, and the table for your User model is users you could just define a belongsToMany and get the information that way:

    public function users()
    {
        return $this->belongsToMany(User::class, 'messages')->distinct();
    }
    

    then:

    return Forum::with(['users' => function($query){
         $query->select('users.id', 'users.name');
    }])->withCount('messages')->paginate(10);
    

    Hope this helps!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错
  • ¥15 单片机学习顺序问题!!
  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
  • ¥15 相敏解调 matlab
  • ¥15 求lingo代码和思路
  • ¥15 公交车和无人机协同运输
  • ¥15 stm32代码移植没反应
  • ¥15 matlab基于pde算法图像修复,为什么只能对示例图像有效