douwen8424 2017-09-21 20:11
浏览 45
已采纳

渴望加载单个多对多关系

I have two models connected via a pivot table with an extra column to track the quantity

class Item extends Eloquent {
    public function containers()
    {
        return $this->belongsToMany('Container', 'items_containers', 'item_id', 'container_id')->withPivot(['quantity']);
    }
}

class Container extends Eloquent { 
    public function items() {
        return $this->belongsToMany('Item', 'items_containers', 'container_id', 'item_id')->withPivot(['quantity']);
    }
}

And a third model for my orders:

class OrderItem extends Eloquent {
    public function originalItem()
    {
        return $this->hasOne('Item', 'id', 'item_id');
    }
    public function container() {
        return $this->hasOne('Container', 'id', 'container_id');
    }

}

What I want is to be able to get the specific data from the pivot table when eager loading the OrderItem models, so I only get the quantity where the item_id and container_id matches what's on the order item.

OrderItems::whereOrderId($orderId)
   ->with(['originalItem', 'container', '???'])
   ->get();

What's the best way to specify the relationship on the OrderItem, or load it in with with?

  • 写回答

2条回答 默认 最新

  • dongye9820 2017-09-22 07:33
    关注

    The following returns what you want:

    $orders = \App\OrderItem::select('item_orders.*', 'items_containers.quantity as quantity')->with('item', 'container')
        ->leftJoin('items_containers', function ($join) {
            $join->on('items_containers.item_id', 'item_orders.item_id')
                ->where('items_containers.container_id', \DB::raw('item_orders.container_id'));
        })
        ->get();
    

    Then you can easily get the quantity.

    $orders->first()->quantity;
    

    That's it.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 arduino控制ps2手柄一直报错
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥85 maple软件,solve求反函数,出现rootof怎么办?
  • ¥15 求chat4.0解答一道线性规划题,用lingo编程运行,第一问要求写出数学模型和lingo语言编程模型,第二问第三问解答就行,我的ddl要到了谁来求了
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名
  • ¥65 汇编语言除法溢出问题
  • ¥15 Visual Studio问题
  • ¥20 求一个html代码,有偿
  • ¥100 关于使用MATLAB中copularnd函数的问题