Gestion des valeurs NULL dans MySQL CONCAT
Lors de la concaténation de plusieurs champs dans MySQL à l'aide de la fonction CONCAT(), il est possible que le résultat devienne NULL si l’un des champs contient des valeurs NULL. Cela peut conduire à des résultats inattendus dans les opérations de récupération de données.
Considérez les données suivantes dans le tableau « appareils » :
affiliate_name affiliate_location model ip os_type os_version cs1 inter Dell 10.125.103.25 Linux Fedora cs2 inter Dell 10.125.103.26 Linux Fedora cs3 inter Dell 10.125.103.27 NULL NULL cs4 inter Dell 10.125.103.28 NULL NULL
Lors de l'exécution de la requête suivante :
SELECT CONCAT(`affiliate_name`,'-',`model`,'-',`ip`,'-',`os_type`,'-',`os_version`) AS device_name FROM devices
on obtient le résultat suivant :
cs1-Dell-10.125.103.25-Linux-Fedora cs2-Dell-10.125.103.26-Linux-Fedora (NULL) (NULL)
Comme on peut le voir, les lignes 3 et 4 renvoient NULL car os_type ou os_version contient NULL. Pour éviter cela, nous pouvons utiliser la fonction COALESCE() pour envelopper chaque champ dans l'expression de concaténation. COALESCE() prend deux valeurs ou plus et renvoie la première valeur non NULL, ou le dernier argument si toutes les valeurs sont NULL.
Par conséquent, la requête modifiée devient :
SELECT CONCAT(COALESCE(`affiliate_name`,''),'-',COALESCE(`model`,''),'-',COALESCE(`ip`,''),'-',COALESCE(`os_type`,''),'-',COALESCE(`os_version`,'')) AS device_name FROM devices
Ceci la requête modifiée renverra désormais le résultat souhaité :
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-
En enveloppant chaque champ dans COALESCE(), nous nous assurons que les valeurs NULL sont ignorées et remplacées par un vide chaîne, ce qui donne un résultat de concaténation non NULL.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!