Когда я присоединяюсь к одной таблице к другой, я получил эту ошибку. я поставил в качестве ключевого слова, но ее не работает он дает мне ошибку, как поле не нашел, как я могу решить эту ошибкуЯ нашел ошибку в запросе, когда я присоединяюсь к другой таблице
Код:
Product::leftjoin('reviews','products.id','=','reviews.productID')
->select(array('products.*',
DB::raw('AVG(rating) as ratings_average')
))
->where(function($query) use ($categoriesID,$brands,$priceArray,$ratingArray)
{
$query->whereIn('categoryID',$categoriesID);
if(count($brands) > 0)
{
$query->whereIn('brandID',$brands);
}
$query->whereBetween('productSellingPrice',$priceArray);
if(count($ratingArray) > 0)
{
$query->whereBetween('ratings_average',$ratingArray);
}
})
->groupBy('products.id')
->get();
Ошибка:
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'ratings_average' in 'where clause' (SQL: select `products`.*, AVG(rating) as ratings_average from `products` left join `reviews` on `products`.`id` = `reviews`.`productID` where (`categoryID` in (9, 11, 31) and `productSellingPrice` between 50 and 5000 and `ratings_average` between 1 and 2) group by `products`.`id`)
Имеется ли в вашей таблице столбец с именем «rating_average»? – TZHX
Я использую DB :: raw ('AVG (рейтинг) как rating_average' @TZHX –
Итак, это «нет»? – TZHX