获取laravel中外键的所有数据

Get all data of foreign key in laravel

目前我这样做是为了获取分支 table 数据:

$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中设置了belongsTo table。
这对我来说很好,但我正在寻找在单个查询中使用它的方法。 我如何使用单个查询获取此数据?

您可以 eager load 您的关系使用 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();