GROUP BY 절 없이 집계가 포함된 MySQL 5.7 쿼리가 실패하는 이유는 무엇입니까?

DDD
풀어 주다: 2024-10-26 01:42:28
원래의
907명이 탐색했습니다.

Why is my MySQL 5.7  query with aggregation failing without a GROUP BY clause?

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 절에 포함되어야 함을 의미합니다.

오류를 해결하려면 다음 두 가지 옵션이 있습니다.

  • MySQL 설정 수정: GROUP BY 없이 집계 쿼리에서 집계되지 않은 열을 허용했던 이전 동작으로 되돌리도록 MySQL 구성을 조정합니다.
  • 쿼리 수정: 다음 예와 같이 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!