使用 laravel 连接多个表

joining multiple tables using laravel

您好,我正在尝试使用 laravel 中的联接来执行以下查询。

select  advertisers.advertiserName,brands.brandName  
        ,campaigns.campaignName,banner_creatives.bannerName         
from vicinity_adman_dev.advertisers
     join vicinity_adman_dev.brands 
     join vicinity_adman_dev.campaigns
     join vicinity_adman_dev.banner_creatives

     on advertisers. advertiserId = brands.advertiserId
     where 
     banner_creatives.campaignId = campaigns.campaignId

到目前为止我做了什么:

  $campaigns =DB::table('brands')

 ->join('advertisers','brands.advertiserId' , '=','advertisers.advertiserId'               
                ->join('campaigns','banner_creatives.campaignId',
                        '=','campaigns.campaignId')  

  select('advertisers.advertiserName','brands.brandName','campaigns.campaignName','banner_creatives.bannerName')   
->get();

第二次加入时出错“banner_creatives.campaignId” 提前致谢

您错过了一个加入。将它添加到其他

$campaigns = DB::table('brands')
               ->join('advertisers', 'brands.advertiserId', '=', 'advertisers.advertiserId')
               ->join('campaigns', 'banner_creatives.campaignId', '=', 'campaigns.campaignId')
               ->join('banner_creatives', 'banner_creatives.bannerCreativeId', '=', 'other_table.bannerCreativeId')
               ->select(
                   'advertisers.advertiserName',
                   'brands.brandName',
                   'campaigns.campaignName',
                   'banner_creatives.bannerName'
               )
               ->get();