Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Fügen Sie eine komplexe Logik in eine einzelne MySQL-Abfrage ein

Verwenden Sie einen Selbstbeitritt:

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

Sie müssen Klauseln hinzufügen, um die Eingabe der Zimmeranzahl zu überprüfen Bedingungen.

Die erzeugte result_id wäre r1.HOTEL_ID .

Sie würden eine einzelne Zeile pro Hotel erhalten.