MySQL의 SELECT DISTINCT와 GROUP BY 성능 비교
MySQL에서는 SELECT DISTINCT
또는 GROUP BY
쿼리를 사용하여 테이블의 고유한 값을 추출할 수 있습니다. 그러나 어떤 방법이 더 나은 성능을 발휘하는지에 대해서는 약간의 모호함이 있습니다.
다음 형식을 고려하세요.
<code class="language-sql">CREATE TABLE users ( id int(10) unsigned NOT NULL auto_increment, name varchar(255) NOT NULL, profession varchar(255) NOT NULL, employer varchar(255) NOT NULL, PRIMARY KEY (id) )</code>
"직업" 필드에 대한 고유 값을 검색하려면 다음 두 가지 쿼리를 사용할 수 있습니다.
쿼리 1(SELECT DISTINCT
):
<code class="language-sql">SELECT DISTINCT u.profession FROM users u</code>
쿼리 2(GROUP BY
):
<code class="language-sql">SELECT u.profession FROM users u GROUP BY u.profession</code>
어느 것이 더 빠릅니까?
이 두 쿼리는 기능적으로는 동일해 보이지만 쿼리 최적화 프로그램에 따라 성능이 달라질 수 있습니다. 일반적으로 SELECT DISTINCT
가 약간 더 빠릅니다.
이는 GROUP BY
이 기본적으로 표시되는 모든 열을 기준으로 그룹화되기 때문입니다. 이 경우 쿼리에 다른 열이 사용되지 않기 때문에 최적화 프로그램은 그룹화가 타당하지 않은지 확인하기 위해 추가 작업을 수행해야 할 수도 있습니다. 반면 SELECT DISTINCT
은 명시적으로 고유한 값을 요청합니다.
결론
대부분의 경우 SELECT DISTINCT
과 GROUP BY
의 성능 차이는 무시할 수 있습니다. 그러나 최적화가 중요한 경우 쿼리 최적화 프로그램의 작업을 단순화하므로 SELECT DISTINCT
을 사용하는 것이 좋습니다.
팁: 확실한 결과를 얻으려면 항상 성능 모니터링 환경에서 두 가지 방법을 모두 테스트하는 것이 좋습니다.
위 내용은 SELECT DISTINCT 또는 GROUP BY: 고유 값에 대해 어떤 MySQL 쿼리가 더 빠릅니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!