쿼리를 해결하기위한 하위 쿼리

하위 쿼리는 쿼리 내의 쿼리로 가장 잘 정의됩니다. 하위 쿼리를 사용하면 쿼리가 런타임에 실행되는 동안 실제로 개발 된 기준에 대한 데이터 행을 선택하는 쿼리를 작성할 수 있습니다. 보다 공식적으로는 다른 SELECT 문의 절 중 하나에서 SELECT 문을 사용하는 것입니다. 사실, 하위 쿼리는 다른 하위 쿼리 내부에있는 다른 하위 쿼리 등에 포함될 수 있습니다. 하위 쿼리는 INSERT, UPDATE 및 DELETE 문 내에 중첩 될 수도 있습니다. 하위 쿼리는 괄호로 묶어야합니다.

하위 쿼리는 단일 값을 반환하는 경우식이 허용되는 모든 위치에서 사용할 수 있습니다. 즉, 단일 값을 반환하는 하위 쿼리도 FROM 절 목록의 개체로 나열 될 수 있습니다. 하위 쿼리가 FROM 절의 일부로 사용될 때 가상 테이블 또는 뷰처럼 취급되기 때문에 인라인 뷰라고합니다. 서브 쿼리는 기본 쿼리의 FROM 절, WHERE 절 또는 HAVING 절에 배치 할 수 있습니다.

Oracle은 WHERE 절에서 최대 255 개의 하위 쿼리 수준 중첩을 허용합니다. FROM 절에 표현 된 중첩 하위 쿼리에는 제한이 없습니다. 실제로 255 개 수준의 제한은 3 ~ 4 개 수준을 넘어서 중첩 된 하위 쿼리가 발생하는 경우가 거의 없기 때문에 실제로 제한이 아닙니다.

하위 쿼리 SELECT 문은 일반 또는 외부 쿼리를 시작하는 데 사용되는 SELECT 문과 매우 유사합니다. 하위 쿼리의 전체 구문은 다음과 같습니다.

( SELECT [DISTINCT] subquery_select_parameter
  FROM {table_name | view_name}
               {table_name | view_name} ...
  [WHERE search_conditions]
  [GROUP BY column_name [,column_name ] ...]
  [HAVING search_conditions] )

하위 쿼리 유형

Single Row Sub Query: 단일 행 출력을 반환하는 하위 쿼리입니다. WHERE 조건에서 사용될 때 단일 행 비교 연산자의 사용을 표시합니다.

Multiple row sub query: 여러 행 출력을 반환하는 하위 쿼리입니다. IN, ANY, ALL과 같은 여러 행 비교 연산자를 사용합니다. 여러 열을 반환하는 하위 쿼리도있을 수 있습니다.

Correlated Sub Query: 상관 하위 쿼리는 외부 쿼리에서 제공하는 데이터에 따라 달라집니다.이 유형의 하위 쿼리에는 EXISTS 연산자를 사용하여 지정된 기준을 충족하는 데이터 행의 존재를 테스트하는 하위 쿼리도 포함됩니다.

단일 행 하위 쿼리

단일 행 하위 쿼리는 외부 쿼리의 결과가 알 수없는 단일 값을 기반으로 할 때 사용됩니다. 이 쿼리 유형을 공식적으로 "단일 행"이라고하지만 이름은 쿼리가 여러 열을 반환하지만 결과의 한 행만 반환 함을 의미합니다. 그러나 단일 행 하위 쿼리는 하나의 열로만 구성된 결과 행 하나만 외부 쿼리에 반환 할 수 있습니다.

아래 SELECT 쿼리에서 내부 SQL은 단 하나의 행, 즉 회사의 최소 급여 만 반환합니다. 차례로이 값을 사용하여 모든 직원의 급여를 비교하고 급여가 최소 급여와 동일한 직원 만 표시합니다.

SELECT first_name, salary, department_id
FROM employees
WHERE salary = (SELECT MIN (salary) 
		FROM employees);

HAVING 절은 쿼리의 그룹 결과를 특정 조건에 따라 제한해야 할 때 사용됩니다. 하위 쿼리의 결과를 그룹 함수와 비교해야하는 경우 외부 쿼리의 HAVING 절에 내부 쿼리를 중첩해야합니다.

SELECT department_id, MIN (salary)
FROM employees
GROUP BY department_id
HAVING MIN (salary)  < (SELECT AVG (salary) FROM employees)

다중 행 하위 쿼리

다중 행 하위 쿼리는 두 개 이상의 결과 행을 상위 쿼리에 반환 할 수있는 중첩 된 쿼리입니다. 다중 행 하위 쿼리는 WHERE 및 HAVING 절에서 가장 일반적으로 사용됩니다. 여러 행을 반환하므로 비교 연산자 집합 (IN, ALL, ANY)으로 처리해야합니다. IN 연산자는 이전 장에서 설명한 것과 동일한 의미를 가지고 있지만 ANY 연산자는 지정된 값을 하위 쿼리에서 반환 된 각 값과 비교합니다. ALL은 값을 하위 쿼리에서 반환 된 모든 값과 비교합니다.

아래 쿼리는 단일 행 하위 쿼리가 여러 행을 반환 할 때 오류를 보여줍니다.

SELECT	first_name, department_id
FROM employees
WHERE department_id = (SELECT department_id FROM employees WHERE LOCATION_ID = 100)
department_id = (select
               *
ERROR at line 4:
ORA-01427: single-row subquery returns more than one row

다중 행 연산자 사용

  • [> ALL] 하위 쿼리에서 반환 된 가장 높은 값 이상

  • [<ALL] 하위 쿼리에서 반환 된 가장 낮은 값보다 작습니다.

  • [<ANY] 하위 쿼리에서 반환 된 가장 높은 값보다 작습니다.

  • [> ANY] 하위 쿼리에서 반환 된 가장 낮은 값 이상

  • [= ANY] 하위 쿼리에서 반환 된 모든 값과 동일 (IN과 동일)

위의 SQL은 아래와 같이 IN 연산자를 사용하여 다시 작성할 수 있습니다.

SELECT	first_name, department_id
FROM employees
WHERE department_id IN (SELECT department_id
                   	    FROM departments
                   	    WHERE LOCATION_ID = 100)

위의 질의에서 IN은 sub 질의에서 반환 된 부서 ID와 일치하고 주 질의의 그것과 비교하여 조건을 만족하는 직원의 이름을 반환합니다.

조인은 위의 쿼리에 더 나은 솔루션이 될 수 있지만 설명을 위해 하위 쿼리가 사용되었습니다.

상관 하위 쿼리

외부 쿼리가 내부 쿼리에서 제공하는 값에 의존하는 일반 하위 쿼리와 달리 상관 하위 쿼리는 내부 쿼리가 외부 쿼리에서 제공하는 값에 의존하는 쿼리입니다. 이는 상관 하위 쿼리에서 내부 쿼리가 외부 쿼리에 의해 선택 될 수있는 각 행에 대해 한 번씩 반복적으로 실행됨을 의미합니다.

상관 된 하위 쿼리는 복잡한 관리 질문에 답하는 결과 테이블을 생성 할 수 있습니다.

아래 SELECT 쿼리를 고려하십시오. 이전에 고려한 하위 쿼리와 달리이 SELECT 문의 하위 쿼리는 기본 쿼리와 독립적으로 확인할 수 없습니다. 외부 쿼리는 별칭 이름이 e1 인 employee 테이블에서 행이 선택되도록 지정합니다. 내부 쿼리는 별칭이 e2 인 직원 테이블의 직원 부서 번호 열 (DepartmentNumber)을 별칭 테이블 이름 e1의 동일한 열과 비교합니다.

SELECT EMPLOYEE_ID, salary, department_id
FROM   employees E
WHERE salary > (SELECT AVG(salary)
                FROM   EMP T
                WHERE E.department_id = T.department_id)

다중 열 하위 쿼리

다중 열 하위 쿼리는 외부 쿼리에 둘 이상의 열을 반환하며 외부 쿼리의 FROM, WHERE 또는 HAVING 절에 나열 될 수 있습니다. 예를 들어, 아래 쿼리는 현재 급여가 1000과 2000 범위에 있고 부서 10 또는 20에서 일하는 직원에 대한 직원의 내역 세부 정보를 보여줍니다.

SELECT first_name, job_id, salary
FROM emp_history
WHERE (salary, department_id) in (SELECT salary, department_id
				  FROM employees
 				  WHERE salary BETWEEN 1000 and 2000 
				  AND department_id BETWEEN 10 and 20)
ORDER BY first_name;

외부 쿼리의 FROM 절에서 다중 열 하위 쿼리를 사용하면 외부 쿼리의 다른 절에서 참조 할 수있는 임시 테이블이 생성됩니다. 이 임시 테이블을보다 공식적으로 인라인보기라고합니다. 하위 쿼리의 결과는 FROM 절의 다른 테이블처럼 처리됩니다. 임시 테이블에 그룹화 된 데이터가 포함 된 경우 그룹화 된 하위 집합은 테이블에서 별도의 데이터 행으로 처리됩니다. 아래 쿼리에서 FROM 절을 고려하십시오. 하위 쿼리로 구성된 인라인보기는 기본 쿼리의 데이터 소스입니다.

SELECT * 
FROM (SELECT salary, department_id
	FROM employees
 	WHERE salary BETWEEN 1000 and 2000);