NULL-Werte verzerren die CONCAT-Funktion in MySQL
Das Ausführen einer CONCAT-Abfrage für eine Tabelle mit NULL-Werten kann zu unerwarteten Ergebnissen führen. Im bereitgestellten Beispiel führen die NULL-Werte in bestimmten Feldern dazu, dass das gesamte CONCAT-Ergebnis NULL wird.
Um dieses Problem zu beheben, kann die Funktion COALESCE verwendet werden, um NULL-Werte ordnungsgemäß zu verarbeiten. COALESCE akzeptiert zwei Argumente: das ausgewertete Feld und den zu ersetzenden Wert, wenn das Feld NULL ist. Indem wir jedes potenziell NULL-Feld in COALESCE einschließen, können wir NULL-Werte durch eine leere Zeichenfolge ('') ersetzen.
Die geänderte Abfrage mit angewendetem COALESCE:
SELECT CONCAT(COALESCE(`affiliate_name`,''),'-',COALESCE(`model`,''),'-',COALESCE(`ip`,''),'-',COALESCE(`os_type`,''),'-',COALESCE(`os_version`,'')) AS device_name FROM devices
Diese Abfrage wird jetzt zurückgegeben das gewünschte Ergebnis, indem NULL-Werte ignoriert und Nicht-NULL-Werte in einer einzigen Zeichenfolge verkettet werden:
cs1-Dell-10.125.103.25-Linux-Fedora cs2-Dell-10.125.103.26-Linux-Fedora cs3-Dell-10.125.103.27- cs4-Dell-10.125.103.28-
Das obige ist der detaillierte Inhalt vonWie kann ich verhindern, dass NULL-Werte meine MySQL CONCAT-Ergebnisse ruinieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!