외부 쿼리에도 나타나는 테이블에 대한 참조를 포함하는 하위 쿼리를 상관 하위 쿼리라고 합니다. 이 경우 MySQL은 내부 쿼리에서 외부 쿼리로 평가합니다. 그것을 이해하기 위해 우리는 'cars' 테이블에서 다음 데이터를 가지고 있습니다 -
mysql> Select * from Cars; +------+--------------+---------+ | ID | Name | Price | +------+--------------+---------+ | 1 | Nexa | 750000 | | 2 | Maruti Swift | 450000 | | 3 | BMW | 4450000 | | 4 | VOLVO | 2250000 | | 5 | Alto | 250000 | | 6 | Skoda | 1250000 | | 7 | Toyota | 2400000 | | 8 | Ford | 1100000 | +------+--------------+---------+ 8 rows in set (0.02 sec)
다음은 외부 쿼리에도 나타나는 'Cars'와 같은 테이블에 대한 참조를 포함하는 하위 쿼리가 있는 두 개의 MySQL 쿼리입니다.
mysql> Select Name from cars WHERE Price < (SELECT AVG(Price) from Cars); +--------------+ | Name | +--------------+ | Nexa | | Maruti Swift | | Alto | | Skoda | | Ford | +--------------+ 5 rows in set (0.00 sec)
위의 쿼리에서 MySQL은 내부 쿼리에서 평가합니다. 즉, 먼저 'Select AVG(Price) from Cars' 내부 쿼리를 평가한 다음 외부 쿼리 'Select Name from Cars Where Price <'를 평가합니다. 마찬가지로 MySQL은 아래 쿼리에서 평가합니다.
mysql> Select Name from cars WHERE Price > (SELECT AVG(Price) from Cars); +--------+ | Name | +--------+ | BMW | | VOLVO | | Toyota | +--------+ 3 rows in set (0.00 sec)