簡體   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