Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> MySQL

เราจะกรองข้อมูลด้วยความช่วยเหลือของแบบสอบถามย่อย MySQL ได้อย่างไร


ด้วยความช่วยเหลือของคำหลัก IN เราสามารถใช้แบบสอบถามย่อยเพื่อกรองข้อมูลได้ เป็นเพราะเราสามารถใช้ผลลัพธ์ของการสืบค้นข้อมูล เช่นเดียวกับที่เราใช้รายการค่ากับตัวดำเนินการ IN เพื่อกรองการสืบค้นตามผลลัพธ์ของการสืบค้นอื่น เคียวรีย่อยปรากฏในวงเล็บหลังคีย์เวิร์ด IN

ตัวอย่าง

เราใช้ข้อมูลจากตารางต่อไปนี้เพื่อแสดงตัวอย่างนี้ −

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 Reservations;
+------+-------------+------------+
| ID   | Customer_id | Day        |
+------+-------------+------------+
|    1 |           1 | 2017-12-30 |
|    2 |           2 | 2017-12-28 |
|    3 |           2 | 2017-12-29 |
|    4 |           1 | 2017-12-25 |
|    5 |           3 | 2017-12-26 |
+------+-------------+------------+
5 rows in set (0.00 sec)

แบบสอบถามด้านล่างใช้ตัวดำเนินการ 'IN' กับแบบสอบถามย่อยและส่งกลับผลลัพธ์หลังจากเปรียบเทียบค่าทั้งหมดที่ส่งคืนโดยแบบสอบถามย่อย

mysql> SELECT * from customers WHERE customer_id IN (Select customer_id from reservations);
+-------------+----------+
| Customer_Id | Name     |
+-------------+----------+
|           1 | Rahul    |
|           2 | Yashpal  |
|           3 | Gaurav   |
+-------------+----------+
3 rows in set (0.00 sec)