MySQL CONCAT renvoie NULL si un champ contient NULL
J'ai les données suivantes dans ma table "devices"
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
J'ai exécuté la requête ci-dessous
SELECT CONCAT(`affiliate_name`,'-',`model`,'-',`ip`,'-',`os_type`,'-',`os_version`) AS device_name
FROM devices
Il renvoie le résultat donné ci-dessous
cs1-Dell-10.125.103.25-Linux-Fedora
cs2-Dell-10.125.103.26-Linux-Fedora
(NULL)
(NULL)
Comment en sortir pour qu'il ignore NULL et que le résultat soit
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-
6 réponses
Convertir le NULL
valeurs avec une chaîne vide en l'enveloppant dans COALESCE
SELECT CONCAT(COALESCE(`affiliate_name`,''),'-',COALESCE(`model`,''),'-',COALESCE(`ip`,''),'-',COALESCE(`os_type`,''),'-',COALESCE(`os_version`,'')) AS device_name
FROM devices
SELECT CONCAT(isnull(`affiliate_name`,''),'-',isnull(`model`,''),'-',isnull(`ip`,''),'-',isnull(`os_type`,''),'-',isnull(`os_version`,'')) AS device_name
FROM devices
Pour avoir la même flexibilité dans CONCAT_WS que dans CONCAT (si vous ne voulez pas le même séparateur entre chaque membre par exemple) utilisez ce qui suit:
SELECT CONCAT_WS("",affiliate_name,':',model,'-',ip,... etc)
CONCAT_WS produit toujours null pour moi si le premier champ est Null. J'ai résolu ce problème en ajoutant une chaîne de longueur zéro au début comme dans CONCAT_WS("",affiliate_name
,'-',model
,'-',ip
,'-',os_type
,'-',os_version
) cependant CONCAT("",affiliate_name
,'-',model
,'-',ip
,'-',os_type
,'-',os_version
) produit Null lorsque le premier champ est Null.
Vous pouvez utiliser l'instruction if comme ci-dessous
select CONCAT(if(affiliate_name is null ,'',affiliate_name),'- ',if(model is null ,'',affiliate_name)) as model from devices