MySQL의 WHERE 절에서 고유한 값을 효율적으로 계산하려면 어떻게 해야 합니까?

Susan Sarandon
풀어 주다: 2024-11-05 09:31:02
원래의
910명이 탐색했습니다.

How Can I Efficiently Count Distinct Values in MySQL's WHERE Clause?

MySQL의 WHERE 절에서 COUNT(*)를 효과적으로 사용

열의 고유 값에 특정 임계값을 초과하는 개수가 있는지 확인하는 것이 일반적입니다. MySQL의 작업. 결과를 필터링하기 위해 WHERE 절에서 COUNT(*)를 사용하는 것이 간단해 보일 수 있지만 이러한 접근 방식은 비효율적일 수 있습니다.

이러한 리소스 집약적 접근 방식을 피하려면 다음 대체 구문을 사용하는 것이 좋습니다.

<code class="sql">SELECT DISTINCT gid
FROM `gd`
GROUP BY gid
HAVING COUNT(*) > 10
ORDER BY lastupdated DESC</code>
로그인 후 복사

GROUP BY 절을 사용하면 MySQL은 gid의 고유한 값을 기준으로 행을 그룹화합니다. 그런 다음 HAVING 절은 COUNT(*) 집계 함수를 각 그룹에 적용하여 개수가 10보다 작은 그룹을 필터링합니다. 마지막으로 ORDER BY 절은 마지막으로 업데이트된 타임스탬프 열을 기준으로 결과를 내림차순으로 정렬합니다.

이 접근 방식은 각 행에 대해 한 번이 아니라 고유한 값당 한 번만 집계를 수행하므로 더 효율적입니다. 이러한 최적화는 행 수가 많은 테이블의 성능을 크게 향상시킬 수 있습니다.

위 내용은 MySQL의 WHERE 절에서 고유한 값을 효율적으로 계산하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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