Laravel Eloquent에서 MySQL의 "Expression #1 of SELECT List Not in GROUP BY" 오류 해결
Laravel Eloquent에서 일반적인 오류가 발생했습니다. groupBy() 메서드를 사용할 때 "SELECT 목록의 표현식 #1이 GROUP BY 절에 없습니다." 오류입니다. 이는 일반적으로 다른 열에서 집계가 수행되는 동안 집계되지 않은 열이 SELECT 목록에 포함될 때 발생합니다.
다음 Laravel Eloquent 쿼리를 고려하세요.
$products = Product::where('status', 1) ->where('stock', '>', 0) ->where('category_id', '=', $category_id) ->groupBy('store_id') ->orderBy('updated_at', 'desc') ->take(4) ->get();
이 쿼리를 실행하면 다음 오류가 발생합니다.
SQLSTATE[42000]: Syntax error or access violation: 1055 Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'myshop.products.id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by (SQL: select * from products where status = 1 and stock > 0 and category_id = 5 group by store_id order by updated_at desc limit 4)
이 문제를 해결하려면 데이터베이스 연결 설정에서 MySQL의 엄격 모드를 비활성화하세요. 이 모드는 실행 중인 쿼리와 충돌할 수 있는 더 엄격한 SQL 구문 및 열 그룹화를 적용합니다.
config/database.php 파일에서 데이터베이스 구성을 수정합니다.
'connections' => [ 'mysql' => [ // Behave like MySQL 5.6 'strict' => false, // Behave like MySQL 5.7 'strict' => true, ] ]
엄격한 설정을 설정합니다. MySQL 연결에서 엄격 모드를 비활성화하려면 옵션을 false로 설정하세요. 이렇게 하면 "GROUP BY에 없는 SELECT 목록의 표현식 #1" 오류가 해결됩니다.
고급 구성 설정에 대한 자세한 내용은 Matt Stauffer의 블로그 게시물을 참조하세요.
위 내용은 Laravel Eloquent의 \'GROUP BY에 없는 SELECT 목록의 표현식 #1\' MySQL 오류를 수정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!