>데이터 베이스 >MySQL 튜토리얼 >Laravel Eloquent의 \'GROUP BY에 없는 SELECT 목록의 표현식 #1\' MySQL 오류를 수정하는 방법은 무엇입니까?

Laravel Eloquent의 \'GROUP BY에 없는 SELECT 목록의 표현식 #1\' MySQL 오류를 수정하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-19 11:27:02995검색

How to Fix Laravel Eloquent's

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

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