>
>
> select case when  t3.date='xxxx' then
>                     select * from table1
> else
>                     select * from table 2
>  from table3  t3             where t3.date='xxxxx'
>
> Problem is that I have to do it in Plain SQL.

you problem is not quite clear.
do you want to output all rows from table1 (or table2)
for each row of table3?
or does table2 only have one row with date='xxxxx' ?
is 'xxxx' the same date as 'xxxxx' in your example?
if so, how can table2's columns be selected.

are you looking for something like:

select * from table1
  where (select date from table3)='xxxx'
UNION ALL
select * from table2
  where (select date from table3)<>'xxxx'


maybe little bit more readable form:

select *
  from table1
 where exists (select 1 from table3 where date = 'xxxx')
union all
select *
  from table2
 where exists (select 1 from table3 where date = 'xxxx');

it's possible with one big disadvantage. This query will do seq scan
both tables and it can be slow on big tables.

Regards
Pavel Stehule

---------------------------(end of broadcast)---------------------------
TIP 2: Don't 'kill -9' the postmaster

Reply via email to