Skip to main content

MySQL CONCAT() function returns NULL when one of the argument field value is NULL - Fix


MySQL String Concatenate Functions - MySQL CONCAT() function returns NULL when one of the argument field value is NULL




In MySQL for concatenating two or more stings or Field values we use CONCAT().It returns the string that results from concatenating the arguments. So even if all the argument fields except one have valid data it will return NULL



Syntax: CONCAT('STRING1','STRING2','STRING3',....)

Example Query: SELECT CONCAT(APPLICANT1, ', ' , APPLICANT2) AS APPLICANTS FROM TBL_APPLICATION;

There is an issue with this function. ie, CONCAT() returns NULL if any of the arguments is NULL.

mysql> SELECT CONCAT('First Name', NULL, 'Last Name');
          >> NULL

Suppose you are fetching a Concatenation string of Applicant names from a MySQL Table

SELECT CONCAT(APPLICANT1, ', ' , APPLICANT2) AS APPLICANTS FROM TBL_APPLICATION;
In this case if APPLICANT2 field is NULL then it will return NULL


You can do a work around on CONCAT() using the IFNULL() to fix this

SELECT CONCAT(IFNULL(APPLICANT1,''),' ',IFNULL(APPLICANT2,'')) AS APPLICANTS

The IFNULL function will check whether the field value is empty , and returns a blank value (which is not NULL)



OTHER OPTION is to use MySQL Concatenate With Separator (CONCAT_WS) Function

CONCAT_WS - Concatenate With Separator

Syntax: CONCAT_WS('SEPARATOR','STRING1','STRING2','STRING3',....)

Example Query: SELECT CONCAT_WS(', ',APPLICANT1,'APPLICANT2') AS APPLICANTS FROM TBL_APPLICATION;

Function skip any NULL values given after the separator string. Example given below:

mysql> SELECT CONCAT_WS(',','Name',NULL,'Family Name');
      >> 'Name,Family Name'

References:
MySQL Tutorial "CONCAT_WS()"
MySQL Tutorial "CONCAT()"
MySQl Control Flow Functions ( IFNULL )

Popular posts from this blog

Strange problem occured while trying to create a CSV file using PHP Script - The file is not seen on FTP but can download using file's absolute path url

Strange problem occured while trying to create a CSV file - The file is not seen on FTP but can download using file's absolute path url Last day I came across a strange problem when I tried to create a csv file on therver using a PHP script. the script was simply writing a given content as a csv file. The file will be created runtime. What happened was, The script executed fine, file handler for new file was created and contents was wrote into the file using fwrite and it returned the number of bytes that was written.

How to get the Query string of a URL using the Javascript (JS)?

JS function get the Query string of a URL or value of each parameter using the Javascript(JS)? If you want to get your current page's url var my_url=document.location; to get the query string part of the url use like this: var my_qry_str= location.search; this will return the part of the url starting from "?" following by query string Lets assume that your current page url is http://www.crozoom.com/2013/page.html?qry1=A&qry2=B then the location.search function will return " ?qry1=A&qry2=B " to exclue "?", do like this:


Urgent Openings for PHP trainees, Andriod / IOS developers and PHP developers in Kochi Trivandrum Calicut and Bangalore. Please Send Your updated resumes to recruit.vo@gmail.com   Read more »
Member
Search This Blog