컴퓨터공학/데이터베이스 DB

Correlated Subquery 상관 서브쿼리

Tonny Kang 2024. 10. 22. 08:23
반응형

서브쿼리 Subquery



DML의 서브쿼리


DELETE



서브쿼리는 WHERE 절에서 사용될 수 있습니다.

DELETE FROM ... WHERE ...

 

예시)
강사의 평균 급여보다 낮은 급여를 받는 모든 강사 삭제

 

DELETE FROM instructor
WHERE salary < (
            SELECT avg (salary)
            FROM instructor);

 

스칼라 Scalar 서브쿼리

  • 문제: 일부 튜플이 삭제되면 평균이 변경됨
    → 하지만 SQL은 먼저 평균을 계산하고 그 값과 비교합니다

INSERT



R에 튜플 삽입
원래는 다음과 같습니다

INSERT INTO R VALUES (attributes)

R에 튜플을 삽입하기 위해
서브쿼리를 사용하면

INSERT INTO R subquery

삽입할 일부 튜플을 관계에서 찾기 위해

 

UPDATE



서브쿼리는 WHERE 절에서 사용될 수 있습니다

UPDATE ... SET ... WHERE ...

 

반응형

Correlation Subquery 상관 서브쿼리



내부 쿼리가 외부 쿼리에서 제공하는 값에 의존함
→ 내부 쿼리는 외부 쿼리의 각 행에 대해 한 번씩 반복적으로 실행됨
따라서 비효율적일 수 있음

  • 하지만 EXISTS 또는 NOT EXISTS 연산자는 JOIN보다 더 효율적일 수 있음
    → 왜냐하면, 서브쿼리에서 행 값이 발견되면 내부 쿼리 검색이 종료됨
    → EXISTS는 True를 반환하고 NOT EXISTS는 False를 반환함

중첩 쿼리는 INTERSECT와 EXCEPT의 대안으로 사용될 수 있습니다

(SELECT R.A, R.B
 FROM R)
INTERSECT
(SELECT S.A, S.B
 FROM S)

 

다음과 같이 표현될 수 있습니다

SELECT R.A, R.B
FROM R
WHERE EXISTS(
            SELECT *
            FROM S
                WHERE R.A=S.A AND R.B=S.B)
728x90
(SELECT R.A, R.B
 FROM R)
EXCEPT
(SELECT S.A, S.B
 FROM S)

 

다음과 같이 표현될 수 있습니다

SELECT R.A, R.B
FROM R
WHERE NOT EXISTS(
            SELECT *
            FROM S
                WHERE R.A=S.A AND R.B=S.B)
반응형