>데이터 베이스 >MySQL 튜토리얼 >SQL에서 WHERE와 HAVING의 차이점 이해

SQL에서 WHERE와 HAVING의 차이점 이해

Linda Hamilton
Linda Hamilton원래의
2024-12-23 00:03:08512검색

Understanding the Difference Between WHERE and HAVING in SQL

SQL의 WHERE와 HAVING의 차이점

WHERE 및 HAVING 절은 모두 SQL 쿼리에서 데이터를 필터링하는 데 사용되지만 용도가 다르며 쿼리 실행의 다양한 단계에 적용됩니다. 자세한 비교는 다음과 같습니다.


1. 목적

  • WHERE 절:

    • 그룹화가 수행되기 전에 행을 필터링합니다.
    • 개별 행에 조건을 지정하는 데 사용됩니다.
  • HAVING 절:

    • GROUP BY 절이 적용된 후 그룹화된 데이터를 필터링합니다.
    • 일반적으로 SUM(), COUNT(), AVG() 등과 같은 집계 함수와 함께 사용됩니다.

2. 신청

  • 어디:

    • 집계 함수(예: SUM, COUNT)와 함께 사용할 수 없습니다.
    • 예:
    SELECT * FROM employees WHERE salary > 50000;
    
    • 연봉이 50,000보다 많은 직원을 필터링합니다.
  • 가지고:

    • 특히 GROUP BY로 생성된 그룹을 필터링하는 데 사용됩니다.
    • 조건에 집계 함수를 사용할 수 있습니다.
    • 예:
    SELECT department, AVG(salary) AS avg_salary
    FROM employees
    GROUP BY department
    HAVING AVG(salary) > 60000;
    
    • 평균연봉이 60,000이 넘는 부서를 필터링합니다.

3. 처형순서

  • 어디:

    • 행이 그룹화되기 전 쿼리 초기에 적용됩니다.
    • 그룹화에 포함되는 행에 영향을 줍니다.
  • 가지고:

    • GROUP BY가 그룹을 생성한 후에 적용됩니다.
    • 그룹별 집계 결과를 필터링합니다.

4. 주요 차이점

측면 WHERE 절 HAVING 절
Aspect WHERE Clause HAVING Clause
Purpose Filters rows before grouping. Filters aggregated groups.
Use with Aggregates Cannot use aggregate functions. Can use aggregate functions.
Execution Order Applied before GROUP BY. Applied after GROUP BY.
Scope Operates on individual rows. Operates on grouped data.
목적 그룹화하기 전에 행을 필터링합니다. 집계된 그룹을 필터링합니다. 집계와 함께 사용 집계 함수를 사용할 수 없습니다. 집계 함수를 사용할 수 있습니다. 실행 명령 GROUP BY 이전에 적용됩니다. GROUP BY 이후에 적용됩니다. 범위 개별 행에서 작동합니다. 그룹화된 데이터에 대해 작동합니다.

WHERE 사용:

SELECT * FROM employees WHERE salary > 50000;
  • 급여가 50,000보다 큰 개별 행을 필터링합니다.

HAVING 사용:

SELECT department, AVG(salary) AS avg_salary
FROM employees
GROUP BY department
HAVING AVG(salary) > 60000;
  • 직원 수가 10명이 넘는 부서를 필터링합니다.

결합된 예:

SELECT employee_id, first_name, salary
FROM employees
WHERE salary > 50000;
  • WHERE: 급여가 30,000보다 큰 행을 필터링합니다.
  • HAVING: 평균 급여가 50,000을 초과하는 그룹을 필터링합니다.

WHERE와 HAVING을 사용해야 하는 경우

  • 간단한 조건(비집계)을 기준으로 행을 필터링하려면 WHERE를 사용하세요.
  • GROUP BY 또는 집계 함수를 적용한 후 그룹을 필터링하려면 HAVING을 사용하세요.

결론

WHERE 절은 그룹화 전 개별 행을 필터링하는 데 중점을 두는 반면, HAVING 절은 그룹화 후 집계된 데이터를 필터링하는 데 중점을 둡니다. 행 수준 및 그룹 수준 필터링을 모두 처리하는 효율적인 SQL 쿼리를 작성하려면 이러한 차이점을 이해하는 것이 중요합니다.

안녕하세요. 저는 Abhay Singh Kathayat입니다!
저는 프론트엔드와 백엔드 기술 모두에 대한 전문 지식을 갖춘 풀스택 개발자입니다. 저는 효율적이고 확장 가능하며 사용자 친화적인 애플리케이션을 구축하기 위해 다양한 프로그래밍 언어와 프레임워크를 사용하여 작업합니다.
제 비즈니스 이메일(kaashshorts28@gmail.com)로 언제든지 연락주세요.

위 내용은 SQL에서 WHERE와 HAVING의 차이점 이해의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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