Intellipaat Back

Explore Courses Blog Tutorials Interview Questions
0 votes
3 views
in SQL by (20.3k points)

MySQL CONCAT returns NULL if any field contain NULL

Ask Question

I have the following data in my 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    

I executed below query

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

FROM devices

It returns result given below

cs1-Dell-10.125.103.25-Linux-Fedora

cs2-Dell-10.125.103.26-Linux-Fedora

(NULL)

(NULL)

How to come out of this so that it should ignore NULL AND result should be

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-

1 Answer

0 votes
by (40.7k points)

Try to convert the NULL values with empty string by wrapping it in COALESCE like this:

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

FROM devices

Related questions

0 votes
1 answer
asked Jul 29, 2019 in SQL by Tech4ever (20.3k points)
0 votes
1 answer
asked Jul 19, 2019 in SQL by Tech4ever (20.3k points)
0 votes
1 answer
0 votes
1 answer

31k questions

32.8k answers

501 comments

693 users

Browse Categories

...