Quick and stupid question.. Does an INNER JOIN affect OUTER JOINed tables?
If i inner join to a table that has been left joined, do I flatten the outer to an inner join?
You can assume, in the following example, that the tables all have a column called ID, and another varying-name column that is unique between tables:
what do I see?
LEFT OUTER JOIN
b.id = a.id
c.id = b.id
1) colA no nulls, colB nulls, colC nulls
Total rows: count(*) of a
2) colA, colB and colC all no nulls
Total rows: lesser of (count(*) of b, count(*) of c)
Last edited by cjard; 03-28-2007 at 05:44 AM.
it seems to be that a left b inner c:
a --> b <--> c
a has 5 rows, 1,2,3,4,5
b has 3 rows, 1,3,5
c has 3 rows, 1,2,3
a --> b generates:
b <--> c added:
a1, b1, c1
a3, b3, c3
So yes, INNER JOINing a table, to a table that was outer joined, flattens the OUTERness of the join, by removing any null columns
To work, it must be:
a --> b --> c
Click Here to Expand Forum to Full Width