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-
102
demandé sur John Woo 2013-04-01 13:59:51

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
181
répondu John Woo 2013-04-01 10:01:32

Utilisez CONCAT_WS à la place:

CONCAT_WS() ne saute pas les chaînes vides. Cependant, il ignore toutes les valeurs NULL après l'argument separator.

SELECT CONCAT_WS('-',`affiliate_name`,`model`,`ip`,`os_type`,`os_version`) AS device_name FROM devices
100
répondu Gerry 2015-10-30 17:13:01
SELECT CONCAT(isnull(`affiliate_name`,''),'-',isnull(`model`,''),'-',isnull(`ip`,''),'-',isnull(`os_type`,''),'-',isnull(`os_version`,'')) AS device_name
FROM devices
10
répondu Harshil 2013-04-01 10:15:32

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)
5
répondu patrick 2015-01-05 13:04:19

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.

2
répondu Ken4Edge 2014-11-27 00:04:18

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
1
répondu DNS 2015-09-24 13:42:26