多个联接同名Laravel

时间:2017-08-23 18:58:29

标签: php mysql laravel laravel-5

我有一个问题,我有4张桌子

Deals
Lists
Lists_Galleries
List_has_deals
Lists_has_gallery

我需要获取img_src_list List_Galleries中的内容,但是来自交易。

这次我有这个变种

$query = ListsDeals::where( $matchDeals )
                    ->where('stock', '>', 0)
                    ->orwhere( $matchOtherDeals )
                    ->whereDate('end_date', '>', date('Y-m-d'))
                    ->limit( 4 )
                    ->offset( 0 )
                    ->orderBy( 'start_date' );

$deals = $query->join( 'list_has_deals', 'deals.id', '=', 'list_has_deals.deal_id'  )
        ->join( 'lists', 'list_has_deals.list_id', '=', 'lists.id' )
        ->join( 'list_has_gallery', 'lists.id', '=', 'list_has_gallery.list_id' )
        ->join( 'lists_galleries', 'list_has_gallery.gallery_id', '=', 'lists_galleries.id' )->get();

这给我结果,但我如何在所有表中都有相同的名称,例如覆盖名称的交易和列表的标题,并且没有得到正确的值,如何获得某些列而不覆盖其他列?问候。

更新

这给了我所有结果总是相同的交易。

$deals = $query->join( 'list_has_deals', 'deals.id', '=', 'list_has_deals.deal_id'  )
        ->join( 'lists', 'list_has_deals.list_id', '=', 'lists.id' )
        ->join( 'list_has_gallery', 'lists.id', '=', 'list_has_gallery.list_id' )
        ->join( 'lists_galleries', 'list_has_gallery.gallery_id', '=', 'lists_galleries.id' )
        ->select([ 'deals.id as deal_id', 'deals.stock as stock', 'deals.price as price', 'deals.price_reduced as price_reduced', 'deals.img_src as img_src', 'deals.title_deal as deal_title' ])->get();

更新

$deals = $query->join( 'list_has_deals', 'deals.id', '=', 'list_has_deals.deal_id'  )
        ->join( 'lists', 'list_has_deals.list_id', '=', 'lists.id' );

    $other = $deals->join( 'list_has_gallery', 'lists.id', '=', 'list_has_gallery.list_id' )
        ->join( 'lists_galleries', 'list_has_gallery.gallery_id', '=', 'lists_galleries.id' )
        ->select([ 'deals.id', 'deals.stock', 'deals.price', 'deals.price_reduced', 'deals.img_src', 'deals.title_deal', 'lists_galleries.img_src_list' ])
        ->addSelect([ 'lists_galleries.img_src_list' ])
        ->get();

1 个答案:

答案 0 :(得分:1)

您可以使用select()仅选择所需的列,并使用别名重命名任何冲突:

$query->select(['lists.title AS title', 'lists_galleries.name AS name', 'lists.id AS id'])->get();

这样你就可以只挑选你需要的那些列并轻松处理冲突。