Is there a conditional string-concatenation ? - Mailing list pgsql-sql

From Andreas
Subject Is there a conditional string-concatenation ?
Date
Msg-id 4CB3DF63.6080909@gmx.net
Whole thread Raw
Responses Re: Is there a conditional string-concatenation ?  (Joshua Tolley <eggyknap@gmail.com>)
Re: Is there a conditional string-concatenation ?  (Osvaldo Kussama <osvaldo.kussama@gmail.com>)
List pgsql-sql
  Hi,
Is there a conditional string-concatenation ?

I'd like to have an elegant way to connect 2 strings with some 3rd 
element between only if there really are 2 strings to connect.

e.g.
MyCat ( 'John', '_', 'Doe' ) --> 'John_Doe'
while
MyCat ( 'John', '_', '' ) --> 'John'
MyCat ( '', '_', 'Doe' ) --> 'Doe'
MyCat ( '', '_', '' ) --> NULL

It should treat  NULL  and  ''  equally as empty
and it should trim each of the 3 elements.

so
MyCat ( '       John     ', '_', NULL ) --> 'John'
MyCat ( 'John', NULL, 'Doe' ) --> 'JohnDoe'




pgsql-sql by date:

Previous
From: Markus Schatten
Date:
Subject: Re: get attribute from XML
Next
From: Joshua Tolley
Date:
Subject: Re: Is there a conditional string-concatenation ?