Solved

Using COALESCE to ignore NULL and empty values

Posted on 2010-09-17
8
725 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
Control application downtime with dependency maps

Visualize the interdependencies between application components better with Applications Manager's automated application discovery and dependency mapping feature. Resolve performance issues faster by quickly isolating problematic components.

 
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

Zoho SalesIQ

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

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

In this article I will describe the Copy Database Wizard method as one possible migration process and I will add the extra tasks needed for an upgrade when and where is applied so it will cover all.
Use this article to create a batch file to backup a Microsoft SQL Server database to a Windows folder.  The folder can be on the local hard drive or on a network share.  This batch file will query the SQL server to get the current date & time and wi…
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…
Familiarize people with the process of retrieving data from SQL Server using an Access pass-thru query. Microsoft Access is a very powerful client/server development tool. One of the ways that you can retrieve data from a SQL Server is by using a pa…

911 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

19 Experts available now in Live!

Get 1:1 Help Now