La clause MySQL IN peut être utilisée à la place de l'opérateur OR avec la clause Where. Il peut être utilisé lorsque la clause where est appliquée pour plusieurs valeurs de la même colonne.
Pour comprendre IN clause, considérez user_table table, qui contient les enregistrements suivants :
mysql> SELECT * FROM user_table; +------+------+------------+--------------------+ | id | name | join_date | no_of_posts | +------+------+------------+--------------------+ | 1 | Jim | 2013-01-24 | 50 | | 2 | Rambo| 2013-05-27 | 20 | | 3 | Jack | 2013-05-06 | 70 | | 4 | Bill | 2013-04-06 | 20 | | 5 | Tara | 2013-06-06 | 30 | +------+------+------------+--------------------+ 5 rows in set (0.00 sec)
Supposons que vous souhaitiez afficher les enregistrements avec no_of_posts égal à 50 et 20 et 70. Cela peut être fait en utilisant OR conditions comme suit
mysql>SELECT * FROM user_table ->WHERE no_of_posts= 50 OR ->no_of_posts= 20 OR no_of_posts= 70; +------+------+------------+--------------------+ | id | name | work_date | no_of_posts | +------+------+------------+--------------------+ | 1 | Jim | 2013-01-24 | 50 | | 2 | Rambo| 2013-05-27 | 20 | | 3 | Jack | 2013-05-06 | 70 | | 4 | Bill | 2013-04-06 | 20 | +------+------+------------+--------------------+ 4 rows in set (0.02 sec)
Utiliser IN clause qui ressemble à :