SQLite coalesce() function


The coalesce() function returns a copy of its first non-NULL argument, or NULL if all arguments are NULL. The function must have at least 2 arguments.



Pictorial Presentation

SQLite COALESEC() pictorial presentation

Example: SQLite coalesce() function

sqlite> SELECT coalesce(NULL, 2, 3);

Sample Output:

coalesce(NULL, 2, 3)
sqlite> SELECT coalesce(NULL, NULL, NULL);

Sample Output:

coalesce(NULL, NULL, NULL)

The following SQLite statement returns date of establishment for the Jex Max Publication, BPP Publication, Ultra Press Inc., Night Publication and Novel Publisher Ltd. For New Harrold Publication,Mountain Publication Summer, Pieterson Grp. of Publishers, the query returns the country, since they don't have any date of establishment (NULL).

SELECT pub_id,coalesce(estd,country,pub_city)
FROM publisher;

Sample Output:

pub_id      coalesce(estd,country,pub_city)
----------  -------------------------------
P001        1969-12-25
P002        1985-10-01
P003        1975-09-05
P004        1948-07-10
P005        1975-01-01
P006        1990-12-10
P007        1950-07-15
P008        2000-01-01

Sample table: publisher

Difference between ifnull() and coalesce() function in SQLite

In SQLite, ifnull() takes two expressions and if the first expression is not NULL, it returns the first expression otherwise it returns the second expression whereas coalesce() function returns the first non-NULL value of a list, or NULL if there are no non-NULL values. See the following examples:

sqlite> SELECT ifnull('Red', 'Green');

Sample Output:

ifnull('Red', 'Green')
sqlite> SELECT ifnull(NULL, 'Green');

Sample Output:

ifnull(NULL, 'Green')
sqlite> SELECT coalesce(NULL, 'Green');

Sample Output:

coalesce(NULL, 'Green')
sqlite> SELECT coalesce(NULL, 'Red', 'Green');

Sample Output:

coalesce(NULL, 'Red', 'Green')
sqlite> SELECT coalesce(NULL, NULL, NULL, 'Red');

Sample Output:

coalesce(NULL, NULL, NULL, 'Red')

Previous: char()
Next: glob()

Follow us on Facebook and Twitter for latest update.