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

การใช้ตัวดำเนินการ 'ALL', 'ANY', 'SOME', 'IN' กับ MySQL subquery คืออะไร?


The 'ALL', 'ANY', 'SOME', 'IN' ตัวดำเนินการเปรียบเทียบค่ากับทุกค่าที่ส่งคืนโดยแบบสอบถามย่อย ตัวดำเนินการเหล่านี้ทั้งหมดต้องปฏิบัติตามตัวดำเนินการเปรียบเทียบ ไวยากรณ์ของการใช้โอเปอเรเตอร์เหล่านี้กับแบบสอบถามย่อยของ MySQL มีดังต่อไปนี้ -

ไวยากรณ์สำหรับการใช้ 'ทั้งหมด'

Operand comparison_operator ALL (subquery)

ไวยากรณ์สำหรับการใช้ 'ANY'

Operand comparison_operator ANY (subquery)

ไวยากรณ์สำหรับการใช้ 'SOME'

Operand comparison_operator SOME (subquery)

รูปแบบของการใช้ 'IN'

Operand comparison_operator IN (subquery)

ตัวอย่าง

เรากำลังใช้ข้อมูลจากตารางต่อไปนี้เพื่อแสดงการใช้ 'ALL', 'ANY', 'SOME', '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)

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

mysql> SELECT customer_id from Customers WHERE customer_id <> ALL(Select customer_id from reservations);
+-------------+
| customer_id |
+-------------+
|           4 |
+-------------+
1 row in set (0.00 sec)

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

mysql> SELECT customer_id from customers WHERE customer_id = ANY(Select customer_id from reservations);
+-------------+
| customer_id |
+-------------+
|           1 |
|           2 |
|           3 |
+-------------+
3 rows in set (0.00 sec)

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

mysql> SELECT customer_id from customers WHERE customer_id = Some(Select customer_id from reservations);
+-------------+
| customer_id |
+-------------+
|           1 |
|           2 |
|           3 |
+-------------+
3 rows in set (0.00 sec)

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

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