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