>  기사  >  백엔드 개발  >  Laravel Eloquent 쿼리 오류를 해결하는 방법: sql_mode=only_full_group_by와 호환되지 않습니까?

Laravel Eloquent 쿼리 오류를 해결하는 방법: sql_mode=only_full_group_by와 호환되지 않습니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-18 12:17:02549검색

How to Resolve Laravel Eloquent Query Error: Incompatible with sql_mode=only_full_group_by?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.