Alexander Kuzmenkov <a.kuzmen...@postgrespro.ru> writes: > [ Inequality-merge-join-v10.patch ]
Just thinking about this patch a bit ... I wonder why you were so quick to reject the UNION approach at the outset. This patch is pretty messy, and it complicates a lot of stuff that is quite fundamental to the planner, and you still end up that the only functionality gain is now we can handle full joins whose conditions include a single btree inequality clause. Nor are we doing that remarkably efficiently ... it's pretty much impossible to do it efficiently, in fact, since if the inputs have M and N rows respectively then the output will have something like (M*N)/2 rows. So it seems to me that if we're going to put sweat into this area at all, our ambition ought to be "we'll successfully perform a FULL JOIN with any join clause whatsoever, though it might take O(M*N) time". Now as far as I can tell, the UNION substitution you proposed is completely valid, although it'd be better to phrase the second step as an antijoin. That is, I believe select * from t1 full join t2 on (anything) is exactly equal to select t1.*, t2.* from t1 left join t2 on (anything) union all select t1.*, t2.* from t2 anti join t1 on (anything) There is one fly in the ointment, which is that we will have to run the join clause twice, so it can't contain volatile functions --- but the merge join approach wouldn't handle that case either. Having to read the inputs twice is not good, but we could put them into CTEs, which fixes any problems with volatility below the join and at least alleviates the performance problem. Since we can't currently do any meaningful qual pushdown through full joins, the optimization-fence aspect of a CTE doesn't seem like an issue either. In short, proceeding like the above when we can't find another plan type for a full join seems like it fixes a far wider variety of cases. The possibility that maybe we could do some of those cases a bit faster isn't sufficiently attractive to me to justify also putting in a mechanism like this patch proposes. We only rarely see complaints at all about can't-do-a-full-join problems, and I do not think this patch would fix enough of those complaints to be worthwhile. regards, tom lane