繁体   English   中英

获取laravel中外键的所有数据

[英]Get all data of foreign key in laravel

目前,我正在这样做以获取分支表数据:

$smlist = SM::where('branch_id','=',$branchid)->select('id','name','branch_id')->get();
    foreach ($smlist as $sm) {
      $sm->b = SM::find($sm->id)->branch;
    }

在branch_id是外键的地方,我也在SM表中设置了beforeTo。
这对我来说很好,但是我正在寻找在单个查询中使用它的方法。 如何使用单个查询获取此数据?

您可以使用with()加载您的关系:

$smlist = SM::with('branch')
            ->where('branch_id','=',$branchid)
            ->select('id','name','branch_id')
            ->get();

您必须使用联接,在这里可以找到文档http://laravel.com/docs/4.2/queries#joins

我认为您可以使用以下方式:

SM::->join('branch', 'branch.id', '=', 'sm.branch_id')
.where('sm.branch_id','=',$branchid)
->select('sm.id','sm.name','sm.branch_id','branch.name')
->get();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM