MySQL Select-Anweisung mit CASE oder IF ELSEIF: Auswahl der richtigen Option
Um die Sichtbarkeit von Produkten anhand der Herstellereinstellungen zu bestimmen, bietet MySQL an zwei Optionen: CASE-Anweisung oder IF ELSEIF-Anweisung. Das Verständnis der Unterschiede zwischen diesen beiden Ansätzen ist entscheidend für die Auswahl der optimalen Lösung.
CASE-Anweisung
Die CASE-Anweisung wertet mehrere Bedingungen aus und gibt einen entsprechenden Wert basierend auf der ersten zurück passende Bedingung. In diesem Fall ist die Bedingung der Produktstatus (Neu oder Gebraucht) und der entsprechende Wert ist die vom Hersteller festgelegte Sichtbarkeit (1, 2 oder 3). Die Syntax lautet wie folgt:
CASE WHEN condition1 THEN value1 WHEN condition2 THEN value2 ... ELSE default_value END
IF ELSEIF-Anweisung
Die IF ELSEIF-Anweisung wertet Bedingungen in sequentieller Reihenfolge aus. Wenn eine Bedingung wahr ist, wird der entsprechende Codeblock ausgeführt. Wenn mehrere Bedingungen wahr sind, wird nur der Codeblock für die erste wahre Bedingung ausgeführt. Die Syntax lautet wie folgt:
IF condition1 THEN code block 1 ELSEIF condition2 THEN code block 2 ... ELSE default code block END IF
Auswahl der richtigen Option
In diesem speziellen Fall ist die CASE-Anweisung die geeignetere Wahl, da sie eine sauberere und sauberere Ausführung ermöglicht besser lesbarer Code. Es ordnet den Produktstatus direkt dem entsprechenden Sichtbarkeitswert zu. Die IF ELSEIF-Anweisung würde mehrere else if-Blöcke erfordern, was den Code komplexer und fehleranfälliger machen würde.
Beispielabfrage mit CASE
Die folgende Abfrage verwendet die CASE-Anweisung um das gewünschte Ergebnis zu erzielen:
SELECT t2.company_name, t2.expose_new, t2.expose_used, t1.title, t1.seller, t1.status, CASE status WHEN 'New' THEN t2.expose_new WHEN 'Used' THEN t2.expose_used ELSE NULL END as 'expose' FROM `products` t1 JOIN manufacturers t2 ON t2.id = t1.seller WHERE t1.seller = 4238
Diese Abfrage ruft effektiv Produktdetails zusammen mit dem mithilfe der CASE-Anweisung berechneten Sichtbarkeitswert ab. Das Ergebnis ist ein einstelliger Belichtungswert für jedes Produkt, der für die bedingte Anzeige verwendet werden kann.
Das obige ist der detaillierte Inhalt vonMySQL CASE vs. IF ELSEIF für Produktsichtbarkeit: Was ist besser?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!