Laravel Eloquent 쿼리 오류: sql_mode=only_full_group_by
Laravel Eloquent 쿼리와 관련된 특정 시나리오에서는 다음과 같은 오류 메시지가 나타날 수 있습니다.
<code class="text">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</code>
이 오류는 SELECT 목록의 모든 열을 그룹화하거나 집계해야 하는 MySQL 엄격 모드로 인해 발생합니다.
해결책: MySQL 엄격 모드 비활성화
이 문제에 대한 가장 쉽고 효과적인 해결책은 데이터베이스 연결 설정에서 MySQL 엄격 모드를 비활성화하는 것입니다. 이는 Database.php 파일에 다음 구성을 추가하여 달성할 수 있습니다.
<code class="php">'connections' => [ 'mysql' => [ // Behave like MySQL 5.6 'strict' => false, // Behave like MySQL 5.7 'strict' => true, ] ]</code>
'strict'를 'false'로 설정하면 sql_mode=only_full_group_by에 의해 부과된 제약 없이 쿼리가 실행될 수 있습니다.
고급 구성
MySQL 엄격 모드 동작을 더욱 세부적으로 제어하려면 해당 주제에 대한 Matt Stauffer의 블로그 게시물을 참조하세요.
<code class="text">https://mattstauffer.com/blog/mysql-config-for-laravel-developers</code>
위 내용은 Laravel Eloquent 쿼리 오류를 해결하는 방법: sql_mode=only_full_group_by와 호환되지 않습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!