Solved

Using COALESCE to ignore NULL and empty values

Posted on 2010-09-17
8
720 Views
Last Modified: 2012-05-10
Hi everyone,

I have stumbled across the coalesce function when trying to write a query that will concatenate 4 column values together. The four columns could have different combinations of NULL and/or empty values. For example ...

Col Name - jointAppelation1     jointAppelation2    jointAppelation3     jointAppelation4
Values           name1                        NULL                     NULL                     name2
                        NULL                         name1                                                name2
                      name1                                                                                    name2

I would like to bring these fields together to create a column that shows the values that are not null or empty, split by commar, for example - name1, name2

This is where I am so far based on an example I found on here ...

 
SELECT 

COALESCE(nullif(rtrim(jointAppellation1), '') + ',' ,'') + ' ' 

+ COALESCE(nullif(rtrim((jointAppellation2), '') + ',' ,'') + ' '

+ COALESCE(nullif(rtrim((jointAppellation3), '') + ',' ,'') + ' '

+ COALESCE(nullif(rtrim((jointAppellation4), '') AS [Joint Applicants]

FROM AccountDetails

WHERE ID = '123456'

Open in new window


I am getting an error saying the rtrim function requires 1 argument?

Hope someone can help. Thanks for your time advance.

0
Comment
Question by:DaiWilliams
8 Comments
 
LVL 13

Expert Comment

by:AielloJ
ID: 33700490

Your syntax of rtrim((jointAppellation2) is causing it to think you are trying to pass more than one argument on lines 3 through 5 of your sample code.  It needs to look like rtrim(jointAppellation2).
0
 
LVL 11

Expert Comment

by:JoeNuvo
ID: 33700512
the first rtrim you missing one (

SELECT
  COALESCE(nullif(rtrim(jointAppellation1), '') + ',' ,'') + ' ' <-- this line  , rtrim need 1 more (
+ COALESCE(nullif(rtrim((jointAppellation2), '') + ',' ,'') + ' '
+ COALESCE(nullif(rtrim((jointAppellation3), '') + ',' ,'') + ' '
+ COALESCE(nullif(rtrim((jointAppellation4), '') AS [Joint Applicants]
FROM AccountDetails
0
 
LVL 2

Expert Comment

by:exoduster
ID: 33700524
Hi.

And this is the truth :)

I think the NULLIF() function is not needed.

Just use help = Books OnLine = BOL.

COALESCE(exp [,...n])  returns first not null expression.

Oh, just use BOL :>

Good luck.
0
 
LVL 11

Expert Comment

by:JoeNuvo
ID: 33700571
exoduster:

DaiWilliams want to get rid of empty string also,
that why he uses NULLIF to return null if field content (after rtrim) equal to '' (empty string)
0
Zoho SalesIQ

Hassle-free live chat software re-imagined for business growth. 2 users, always free.

 
LVL 7

Expert Comment

by:gsiric
ID: 33700663
Here is working SQL

select decode(substr(result,length(result),1),',',substr(result,1,length(result)-1),result) from (
SELECT 
  decode(rtrim(jointAppellation1),null,'', rtrim(jointAppellation1) ||  ',')  || 
  decode(rtrim(jointAppellation2),null,'', rtrim(jointAppellation2) ||  ',')  ||
  decode(rtrim(jointAppellation3),null,'', rtrim(jointAppellation3) ||  ',')  ||
  rtrim(jointAppellation4) as result
from AccountDetails);

Open in new window

0
 
LVL 7

Expert Comment

by:gsiric
ID: 33700686
ups i tought it was Oracle - ignore my last comment
0
 
LVL 11

Accepted Solution

by:
JoeNuvo earned 500 total points
ID: 33700745
seem I'm mistake about open bracket
below code should be correct open/close pair
SELECT 

  COALESCE(nullif(rtrim(jointAppellation1), '') + ',' ,'') + ' ' 

+ COALESCE(nullif(rtrim(jointAppellation2), '') + ',' ,'') + ' '

+ COALESCE(nullif(rtrim(jointAppellation3), '') + ',' ,'') + ' '

+ COALESCE(nullif(rtrim(jointAppellation4), '') ,'') AS [Joint Applicants]

FROM AccountDetails

WHERE ID = '123456'

Open in new window

0
 

Author Comment

by:DaiWilliams
ID: 33701050
Thankyou for this so far. I seem to be having an issue when I add other columns to the query and also it doesnt seem to work with the where clause. When I take the where clause out it works. Here is how I am building the query now ...


SELECT id

,AccountNo

,MainAccountHolder

, COALESCE(nullif(rtrim(jointAppellation1), '') + ',' ,'') + ' ' 

+ COALESCE(nullif(rtrim(jointAppellation2), '') + ',' ,'') + ' '

+ COALESCE(nullif(rtrim(jointAppellation3), '') + ',' ,'') + ' '

+ COALESCE(nullif(rtrim(jointAppellation4), '') ,'') AS [Joint Applicants]

FROM AccountDetails

WHERE ID = '123456'

Open in new window

0

Featured Post

How your wiki can always stay up-to-date

Quip doubles as a “living” wiki and a project management tool that evolves with your organization. As you finish projects in Quip, the work remains, easily accessible to all team members, new and old.
- Increase transparency
- Onboard new hires faster
- Access from mobile/offline

Join & Write a Comment

If you have heard of RFC822 date formats, they can be quite a challenge in SQL Server. RFC822 is an Internet standard format for email message headers, including all dates within those headers. The RFC822 protocols are available in detail at:   ht…
How to leverage one TLS certificate to encrypt Microsoft SQL traffic and Remote Desktop Services, versus creating multiple tickets for the same server.
Familiarize people with the process of utilizing SQL Server functions from within Microsoft Access. Microsoft Access is a very powerful client/server development tool. One of the SQL Server objects that you can interact with from within Microsoft Ac…
This videos aims to give the viewer a basic demonstration of how a user can query current session information by using the SYS_CONTEXT function

760 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

14 Experts available now in Live!

Get 1:1 Help Now