>  기사  >  데이터 베이스  >  HAVING 절을 사용하여 MySQL에서 그룹화된 결과를 효율적으로 필터링하는 방법은 무엇입니까?

HAVING 절을 사용하여 MySQL에서 그룹화된 결과를 효율적으로 필터링하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-07 20:24:03209검색

How to Efficiently Filter Grouped Results in MySQL using the HAVING Clause?

MySQL의 HAVING 절을 사용하여 그룹화된 결과 필터링

MySQL에서 실행하려는 쿼리는 특정 항목을 기반으로 행을 필터링하는 것을 목표로 합니다. 그룹의 행 수에 적용되는 조건입니다. WHERE 절에서 COUNT(*)를 사용하는 것은 일반적인 접근 방식이지만 실제로는 리소스 집약적일 수 있습니다.

또는 그룹화된 데이터를 필터링하는 더 효율적인 방법을 제공하는 MySQL의 HAVING 절을 활용할 수도 있습니다. HAVING을 사용하여 동일한 결과를 얻을 수 있는 방법은 다음과 같습니다.

SELECT gid
FROM `gd`
GROUP BY gid
HAVING COUNT(*) > 10
ORDER BY lastupdated DESC

이 쿼리를 분석해 보겠습니다.

  • GROUP BY gid는 gid 열을 기준으로 행을 그룹화하고 모든 행을 다음과 같이 집계합니다. 동일한 gid 값.
  • HAVING COUNT(*) > 10은 각 그룹 내의 행 수가 10보다 큰 그룹을 필터링합니다.
  • ORDER BY lastupdated DESC는 마지막 업데이트된 열을 기준으로 결과 행을 내림차순으로 정렬합니다.

By HAVING 절을 활용하는 이 쿼리는 행이 10개 미만인 그룹을 효율적으로 제거하고 원하는 결과를 제공합니다. 이 접근 방식은 각 개별 행에 대해 COUNT(*)를 계산하는 오버헤드를 방지하므로 데이터 세트가 큰 시나리오에서 특히 유용합니다.

위 내용은 HAVING 절을 사용하여 MySQL에서 그룹화된 결과를 효율적으로 필터링하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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