เพื่อให้เข้าใจว่าเรากำลังใช้ข้อมูลจากตารางต่อไปนี้ -
mysql> Select * from Customers; +-------------+----------+ | Customer_Id | Name | +-------------+----------+ | 1 | Rahul | | 2 | Yashpal | | 3 | Gaurav | | 4 | Virender | +-------------+----------+ 4 rows in set (0.00 sec) mysql> Select * from Reserve; +------+------------+ | ID | Day | +------+------------+ | 1 | 2017-12-30 | | 2 | 2017-12-28 | | 2 | 2017-12-25 | | 1 | 2017-12-24 | | 3 | 2017-12-26 | +------+------------+ 5 rows in set (0.00 sec)
ต่อไปนี้เป็นแบบสอบถามย่อยที่จะค้นหาชื่อของลูกค้าทั้งหมดที่ยังไม่ได้จองรถใด ๆ
mysql> Select Name from customers where customer_id NOT IN (Select id From reserve); +----------+ | Name | +----------+ | Virender | +----------+ 1 row in set (0.00 sec)
ตอนนี้ ด้วยความช่วยเหลือของขั้นตอนต่อไปนี้ เราสามารถแปลงแบบสอบถามย่อยด้านบนเป็น RIGHT JOIN -
-
ย้ายตาราง 'ลูกค้า' ที่มีชื่ออยู่ในข้อความค้นหาย่อยไปยังส่วนคำสั่ง FROM และรวมเข้ากับ 'จอง' โดยใช้ RIGHT JOIN
-
ส่วนคำสั่ง WHERE จะเปรียบเทียบคอลัมน์ customer_id กับรหัสที่ส่งคืนจากเคียวรีย่อย ดังนั้นให้แปลงนิพจน์ IN เป็นการเปรียบเทียบโดยตรงอย่างชัดเจนระหว่างคอลัมน์ id ของสองตารางในส่วนคำสั่ง FROM
-
ในส่วนคำสั่ง WHERE จำกัดเอาต์พุตไว้ที่แถวที่มี NULL ในตาราง "สำรอง"
mysql> SELECT Name from reserve RIGHT JOIN customers ON customer_id = Id WHERE Id IS NULL; +----------+ | Name | +----------+ | Virender | +----------+ 1 row in set (0.00 sec)