Mysql
 sql >> Base de données >  >> RDS >> Mysql

Inclure une logique complexe dans une seule requête MySQL

Utiliser une auto-jointure :

SELECT r1.HOTEL_ID, r1.MAX_ADULTS, r1.NO_OF_ROOMS,
    r2.MAX_ADULTS, r2.NO_OF_ROOMS,
    r3.MAX_ADULTS, r3.NO_OF_ROOMS,
FROM rooms AS r1
INNER JOIN rooms AS r2 ON r1.HOTEL_ID=r2.HOTEL_ID
INNER JOIN rooms AS r3 ON r1.HOTEL_ID=r3.HOTEL_ID
WHERE r1.MAX_ADULTS=1
AND r2.MAX_ADULTS=2
AND r3.MAX_ADULTS=3

Vous devrez ajouter des clauses pour vérifier le nombre de pièces saisi conditions.

Le result_id généré serait r1.HOTEL_ID .

Vous obtiendrez une seule ligne par hôtel.