I am trying to solve the following problem. I have a certain column,
to_state, that can take a finite set of values. I want to make sure that
my query always returns those sets of finite values, even if not all of
the values are represented in the results. In essence, I am looking to
expand the result returned by the query by using a right join.

 

When I do the following simple query, this seems to work. 

 

create table hat (the_hat integer);

insert into hat values (1),(2),(3);

create table cat (the_hat integer);

insert into cat values (2),(3),(4),(5);

 

select the_hat from hat

right join cat c using(the_hat)

 

The right join changes the results query from 1,2,3 to 2,3,4,5.

 

 

However, when I use this on my actual query, I don't get any additional
rows by adding the right join.

 

select to_state from deal_trans_info 

right join (select distinct to_state from deal_trans_info where deal =
'02FF1') foo using(to_state)

where deal = '02FF1' and 

pool_id = 'C2V' and 

coll_type = 'ARM 228' and 

from_state = 'CBNA' and

"month" = '20090701' 

 

I can't send the actual data since it is too big, but it seems like this
is analogous to the simple query above.

 

If anyone has any suggestions, that would be great.

 

Thanks,

 

Andrew

 

 

Reply via email to