我想在我的数据库中返回游戏评论的平均分数。我正在使用Laravel 4构建我的网站。
表格结构:
GAMES (id, title, etc)
REVIEWS (game_id, user_id, score, etc)
控制器:
public function singleGame($id)
{
$game = Game::find($id);
if ($game)
{
return View::make('game')->with('game', $game);
}
else
{
return Redirect::to('/');
}
}
我的想法是希望在我的观点中通过$ game->平均值返回游戏的平均分数,但我无法通过摆弄我的游戏模型来产生预期的结果。
游戏模型:
public function scores()
{
return $this->hasMany('Review')->avg('score');
}
我已经尝试了一些可用于查询构建器的方法,但是当涉及到Laravel / PHP时,我仍在学习绳索,所以我有点卡住了。也许我应该以不同的方式解决问题?
感谢。
答案 0 :(得分:23)
以下是两种选择:
可读性(两个查询)
$game = Game::find(1);
$game->average = $game->reviews()->avg('score');
请注意,这假设您的游戏模型中的关系具有评论功能。
public function reviews()
{
return $this->belongsTo('Game');
}
此替代方案正在使用avg aggregate功能。 QueryBuilder提供的聚合函数仅返回聚合标量。
效果(一次查询)
如果您真的想在一个查询中执行此操作。这是另一种选择:
$game = Game::select('games.*', DB::raw('avg(reviews.score) AS average'))
->join('reviews', 'reviews.game_id', '=', 'game.id')
->groupBy('reviews.game_id')
->where('game.id', '=', 1)
->first();