Given three tables: a, b, c ; each consist of a 'keyfld' and a field called
'foo':
     tbl a       tbl b         tbl c
   ---------   ---------     ---------
   a.keyfld    b.keyfld       c.keyfld
   a.foo1      b.foo2         c.foo3

I want to always return all of tbl a; and I want to return b.foo2 and c.foo3
if
they can be joined to based on keyfld.a; I know that it will involve a LEFT
OUTER
JOIN on table a, but have not seen any examples of joins like this on 3 or
more
tables.

select a.keyfld, a.foo1, b.foo2, c.foo3
from a, b, c
where a.keyfld = <some value>
and   a.keyfld = b.keyfld
and   a.keyfld = c.keyfld;

Results could look like this:
  a.keyfld  a.foo1   b.foo2  c.foo3
    xxxx     xxxx     xxxx    (null)
    xxxx     xxxx    (null)    xxxx
    xxxx     xxxx    (null)   (null)
    xxxx     xxxx     xxxx     xxxx



---------------------------(end of broadcast)---------------------------
TIP 9: In versions below 8.0, the planner will ignore your desire to
       choose an index scan if your joining column's datatypes do not
       match

Reply via email to