我有两种模式,啤酒和分布,它们具有多对多的关系。枢轴模型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');
}
}
答案 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个查询。