查询“跨越”数据透视表

时间:2015-03-31 03:46:05

标签: mysql laravel orm eloquent pivot

我有两种模式,啤酒和分布,它们具有多对多的关系。枢轴模型hasMany桶,其中包含啤酒的一些相关信息,例如定价和状态。当我建立啤酒指数时,我需要啤酒模型,分销商模型和桶模型的所有信息。我想弄清楚的是如何以有效的方式查询所有信息。这是我目前的查询:

Keg的地位是:

public function scopeStatus($query, $status)
{
    return $query->where('status', '=', $status);
}

我用以下方法建立啤酒索引:

    $kegs = Keg::status($status)->get();
    $beers=[];
    foreach ($kegs as $keg){
        $beer = Beer::find($keg->beer_distribution->beer_id);
        $distributor = Distributor::find($keg->beer_distribution->distributor_id);
        $beers[]=[
        'beer' => $beer,
        'keg' => $keg,
        'distributor' => $distributor];
    }

    return $beers;

我知道这是一个慢查询,但我不知道如何在单个查询中执行此操作。有没有办法可以更快地运行它?

一些相关的型号代码:

class Beer extends Eloquent {

    public function distributors()
    {
            return $this->belongsToMany('Distributor', 'beer_distributions');
    }



class BeerDistribution extends Eloquent {

    protected $fillable = ['beer_id', 'distributor_id'];

    public function kegs()
    {
        return $this->hasMany('Keg', 'beer_distribution_id');
    }



class Distributor extends Eloquent {

  public function beers()
  {
      return $this->belongsToMany('Beer', 'beer_distributions');
  }



class Keg extends Eloquent {

  public function scopeStatus($query, $status)
  {
    return $query->where('status', '=', $status);
  }

  public function beerDistribution()
  {
    return $this->belongsTo('BeerDistribution');
  }

}

1 个答案:

答案 0 :(得分:0)

所以我发现我真正需要做的是在我的Keg模型上添加我的查询构建关系(这是关系嵌套中最胖的“向下”),然后使用急切加载!

我现在像这样建立我的啤酒索引:

$beers=[];
foreach (Keg::status($status)
    ->with('kegsize', 
        'beerDistribution.beer.brewery',
        'beerDistribution.beer.style', 
        'beerDistribution.distributor')->get() as $keg){
  $beers[]=$keg;
}
return $beers;

这让我总共得到了10个查询。