Maison  >  Article  >  base de données  >  Comment pouvons-nous simuler une requête MySQL INTERSECT qui renvoie plusieurs expressions ?

Comment pouvons-nous simuler une requête MySQL INTERSECT qui renvoie plusieurs expressions ?

王林
王林avant
2023-09-20 09:09:021240parcourir

我们如何模拟返回多个表达式的 MySQL INTERSECT 查询?

Puisque nous ne pouvons pas utiliser la requête INTERSECT dans MySQL, nous utiliserons l'opérateur EXIST pour simuler la requête INTERSECT. Cela peut être compris à travers l'exemple suivant -

Exemple

Dans cet exemple, nous avons deux tables, à savoir Student_detail et Student_info avec les données suivantes -

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)

Maintenant, utilisez l'opérateur EXIST avec la clause WHERE La requête suivante simulera INTERSECT pour renvoie "studentid", nom, adresse (où le nom n'est pas "Yashpal") qui existe dans les deux tables -

mysql>Select Student_detail.studentid,Student_detail.name, student_detail.address FROM student_detail WHERE Student_detail.studentid >100 AND EXISTS (SELECT * FROM Student_info WHERE Student_info.Name <> &#39;Yashpal&#39; AND Student_info.studentid = Student_detail.studentid AND Student_info.name = Student_detail.name);
+-----------+--------+------------+
| studentid | name   | address    |
+-----------+--------+------------+
|       105 | Gaurav | Chandigarh |
|       130 | Ram    | Jhansi     |
|       132 | Shyam  | Chandigarh |
|       133 | Mohan  | Delhi      |
+-----------+--------+------------+
4 rows in set (0.00 sec)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer