MySQL CONCAT возвращает NULL, если любое поле содержит NULL



у меня есть следующие данные в таблице "устройства"



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


Я выполнил ниже запрос



SELECT CONCAT(`affiliate_name`,'-',`model`,'-',`ip`,'-',`os_type`,'-',`os_version`) AS device_name
FROM devices


возвращает результат приведенный ниже



cs1-Dell-10.125.103.25-Linux-Fedora
cs2-Dell-10.125.103.26-Linux-Fedora
(NULL)
(NULL)


как выйти из этого, так что он должен игнорировать NULL и результат должен быть



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-
772   6  

6 ответов:

преобразование NULL значения с пустой строкой, завернув его в COALESCE

SELECT CONCAT(COALESCE(`affiliate_name`,''),'-',COALESCE(`model`,''),'-',COALESCE(`ip`,''),'-',COALESCE(`os_type`,''),'-',COALESCE(`os_version`,'')) AS device_name
FROM devices

использовать CONCAT_WS вместо:

CONCAT_WS() не пропускает пустые строки. Однако он пропускает любые нулевые значения после аргумента разделителя.

SELECT CONCAT_WS('-',`affiliate_name`,`model`,`ip`,`os_type`,`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

чтобы иметь такую же гибкость в CONCAT_WS, как и в CONCAT (если вы не хотите, чтобы один и тот же разделитель между каждым членом, например), используйте следующее:

SELECT CONCAT_WS("",affiliate_name,':',model,'-',ip,... etc)

CONCAT_WS по-прежнему производит null для меня, если первое поле равно Null. Я решил это, добавив строку нулевой длины в начале, как в CONCAT_WS ("",affiliate_name,'-',model,'-',ip,'-',os_type,'-',os_version) однако CONCAT ("",affiliate_name,'-',model,'-',ip,'-',os_type,'-',os_version) производит Null, когда первое поле равно Null.

вы можете использовать оператор if, как показано ниже

select CONCAT(if(affiliate_name is null ,'',affiliate_name),'- ',if(model is null ,'',affiliate_name)) as model from devices

Comments

    Ничего не найдено.