mirror of https://github.com/postgres/postgres
Fix a bug in the original implementation of redundant-join-clause removal:
clauses in which one side or the other references both sides of the join cannot be removed as redundant, because that expression won't have been constrained below the join. Per report from Sergey Burladyan. CVS HEAD does not contain this bug due to EquivalenceClass rewrite, but it seems wise to include the regression test for it anyway.
This commit is contained in:
parent
bc421c35b1
commit
ed5d55dafe
|
@ -2250,3 +2250,19 @@ WHERE d.f1 IS NULL;
|
|||
9999
|
||||
(3 rows)
|
||||
|
||||
--
|
||||
-- regression test for problems of the sort depicted in bug #3494
|
||||
--
|
||||
create temp table tt5(f1 int, f2 int);
|
||||
create temp table tt6(f1 int, f2 int);
|
||||
insert into tt5 values(1, 10);
|
||||
insert into tt5 values(1, 11);
|
||||
insert into tt6 values(1, 9);
|
||||
insert into tt6 values(1, 2);
|
||||
insert into tt6 values(2, 9);
|
||||
select * from tt5,tt6 where tt5.f1 = tt6.f1 and tt5.f1 = tt5.f2 - tt6.f2;
|
||||
f1 | f2 | f1 | f2
|
||||
----+----+----+----
|
||||
1 | 10 | 1 | 9
|
||||
(1 row)
|
||||
|
||||
|
|
|
@ -2250,3 +2250,19 @@ WHERE d.f1 IS NULL;
|
|||
9999
|
||||
(3 rows)
|
||||
|
||||
--
|
||||
-- regression test for problems of the sort depicted in bug #3494
|
||||
--
|
||||
create temp table tt5(f1 int, f2 int);
|
||||
create temp table tt6(f1 int, f2 int);
|
||||
insert into tt5 values(1, 10);
|
||||
insert into tt5 values(1, 11);
|
||||
insert into tt6 values(1, 9);
|
||||
insert into tt6 values(1, 2);
|
||||
insert into tt6 values(2, 9);
|
||||
select * from tt5,tt6 where tt5.f1 = tt6.f1 and tt5.f1 = tt5.f2 - tt6.f2;
|
||||
f1 | f2 | f1 | f2
|
||||
----+----+----+----
|
||||
1 | 10 | 1 | 9
|
||||
(1 row)
|
||||
|
||||
|
|
|
@ -424,3 +424,19 @@ LEFT JOIN (
|
|||
WHERE c.f1 IS NULL
|
||||
) AS d ON (a.f1 = d.f1)
|
||||
WHERE d.f1 IS NULL;
|
||||
|
||||
--
|
||||
-- regression test for problems of the sort depicted in bug #3494
|
||||
--
|
||||
|
||||
create temp table tt5(f1 int, f2 int);
|
||||
create temp table tt6(f1 int, f2 int);
|
||||
|
||||
insert into tt5 values(1, 10);
|
||||
insert into tt5 values(1, 11);
|
||||
|
||||
insert into tt6 values(1, 9);
|
||||
insert into tt6 values(1, 2);
|
||||
insert into tt6 values(2, 9);
|
||||
|
||||
select * from tt5,tt6 where tt5.f1 = tt6.f1 and tt5.f1 = tt5.f2 - tt6.f2;
|
||||
|
|
Loading…
Reference in New Issue