| From: | Gary Doades <gpd(at)cwcom(dot)net> | 
|---|---|
| To: | pgsql-general(at)postgresql(dot)org | 
| Subject: | Re: Default value if query returns 0 rows? | 
| Date: | 2004-09-17 15:43:18 | 
| Message-ID: | ic1mk0dfj3bslpccl2oavtrf8msb80dba0@4ax.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-general | 
On Fri, 17 Sep 2004 11:03:48 -0400 (EDT), lars(at)oddbit(dot)com (Lars
Kellogg-Stedman) wrote:
>Hello,
>
>I have a simple two-column table mapping names to ids.  I'd like to write a
>select statement that will return a default value if a given name isn't
>found in the table.  That is, I want something equivalent to the following
>pseudocode:
>
>  if exists (select 1 from map where name = 'foo') then
>    select id from map where name = 'foo'
>  else
>    select -1
>  end if
>
>I think I can see how to do this by writing a pl/pgsql function, but I'm
>curious if it's possible to do this completely as part of a select
>statement.  I've toyed with CASE expressions, but the fact that a missing
>value returns 0 rows continues to foil me.
>
>Thanks,
>
>-- Lars
try something like:
select case 
	when count(*) > 0 then (select id from map where name = 'foo')
	when count(*) = 0 then -1
      end as id
 from map where name = 'foo'
cheers,
Gary.
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Christian Mangold | 2004-09-17 15:54:17 | Re: Default value if query returns 0 rows? | 
| Previous Message | Bruno Wolff III | 2004-09-17 15:31:51 | Re: Default value if query returns 0 rows? |