집 >데이터 베이스 >MySQL 튜토리얼 >GROUP BY 절 없이 집계가 포함된 MySQL 5.7 쿼리가 실패하는 이유는 무엇입니까?
MySQL 5.7에서 집계 쿼리에는 GROUP BY가 필요합니다.
Q: MySQL 5.7.14로 업그레이드한 후 쿼리를 실행할 때 오류가 발생합니다. GROUP BY 절 없이. SELECT 목록의 집계(COUNT) 및 집계되지 않은 열을 포함하는 쿼리는 이전에 이전 시스템에서 작동했습니다.
A: MySQL 버전 5.7.5 이상에서는 기본 동작이 변경되었습니다. 데이터를 집계할 때 GROUP BY 사용을 강제합니다. 이는 SELECT 절에서 COUNT와 같은 함수를 사용할 때 집계되지 않은 모든 열이 GROUP BY 절에 포함되어야 함을 의미합니다.
오류를 해결하려면 다음 두 가지 옵션이 있습니다.
<code class="sql">SELECT id, password, COUNT(id) AS count FROM users WHERE email = :email GROUP BY id, password LIMIT 1</code>
MySQL 5.7.5 이상에는 예외가 있다는 점에 유의하는 것이 중요합니다. 집계되지 않은 열이 WHERE 절의 필터를 사용하여 단일 값으로 제한된 경우. 이 경우 집계되지 않은 열은 GROUP BY 절에서 제외될 수 있습니다. 자세한 내용은 공식문서를 참고하세요.
위 내용은 GROUP BY 절 없이 집계가 포함된 MySQL 5.7 쿼리가 실패하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!