MySQL에서는 MINUS 쿼리를 사용할 수 없으므로 LEFT JOIN을 사용하여 MINUS 쿼리를 시뮬레이션합니다. 다음 예를 통해 이해할 수 있습니다.
예시
이 예에서 다음 데이터가 있는 Student_detail 및 Student_info라는 두 개의 테이블이 있습니다.
mysql> Select * from Student_detail; +-----------+---------+------------+------------+ | studentid | Name | Address | Subject | +-----------+---------+------------+------------+ | 101 | YashPal | Amritsar | History | | 105 | Gaurav | Chandigarh | Literature | | 130 | Ram | Jhansi | Computers | | 132 | Shyam | Chandigarh | Economics | | 133 | Mohan | Delhi | Computers | | 150 | Rajesh | Jaipur | Yoga | | 160 | Pradeep | Kochi | Hindi | +-----------+---------+------------+------------+ 7 rows in set (0.00 sec) mysql> Select * from Student_info; +-----------+-----------+------------+-------------+ | studentid | Name | Address | Subject | +-----------+-----------+------------+-------------+ | 101 | YashPal | Amritsar | History | | 105 | Gaurav | Chandigarh | Literature | | 130 | Ram | Jhansi | Computers | | 132 | Shyam | Chandigarh | Economics | | 133 | Mohan | Delhi | Computers | | 165 | Abhimanyu | Calcutta | Electronics | +-----------+-----------+------------+-------------+ 6 rows in set (0.00 sec)
이제 LEFT JOIN을 사용하는 다음 쿼리는 MINUS를 시뮬레이션하여 student_info에는 'studentid' 값을 반환하지만 Student_detail 테이블에는 반환하지 않습니다.
mysql> SELECT studentid from student_info LEFT JOIN Student_detail USING(studentid) WHERE student_detail.studentid IS NULL; +-----------+ | studentid | +-----------+ | 165 | +-----------+ 1 row in set (0.07 sec)
이제 다음 쿼리는 위 쿼리의 반대 결과를 제공합니다. 즉, student_detail에는 'studentid' 값을 반환하지만 Student_info 테이블에는 반환하지 않습니다.
mysql> SELECT studentid from student_detail LEFT JOIN Student_info USING(studentid) WHERE student_info.studentid IS NULL; +-----------+ | studentid | +-----------+ | 150 | | 160 | +-----------+ 2 rows in set (0.00 sec)