เนื่องจากเราไม่สามารถใช้การสืบค้น MINUS ใน MySQL เราจะใช้ 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 เพื่อคืนค่า 'studentid' ใน student_info แต่ไม่แสดงในตาราง 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)
ตอนนี้ ข้อความค้นหาต่อไปนี้จะให้ผลลัพธ์ที่ตรงกันข้ามกับข้อความค้นหาด้านบน กล่าวคือ จะส่งคืนค่า 'studentid' ในรูปแบบ student_detail แต่ไม่แสดงในตาราง 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)