mirror of
https://github.com/postgres/postgres.git
synced 2025-07-03 20:02:46 +03:00
Fix incorrect printing of queries with duplicated join names.
Given a query in which multiple JOIN nodes used the same alias (which'd necessarily be in different sub-SELECTs), ruleutils.c would assign the JOIN nodes distinct aliases for clarity ... but then it forgot to print the modified aliases when dumping the JOIN nodes themselves. This results in a dump/reload hazard for views, because the emitted query is flat-out incorrect: Vars will be printed with table names that have no referent. This has been wrong for a long time, so back-patch to all supported branches. Philip Dubé Discussion: https://postgr.es/m/CY4PR2101MB080246F2955FF58A6ED1FEAC98140@CY4PR2101MB0802.namprd21.prod.outlook.com
This commit is contained in:
@ -769,6 +769,41 @@ View definition:
|
||||
FROM temp_view_test.tx1 tx1_1
|
||||
WHERE tx1.y1 = tx1_1.f1));
|
||||
|
||||
-- Test aliasing of joins
|
||||
create view view_of_joins as
|
||||
select * from
|
||||
(select * from (tbl1 cross join tbl2) same) ss,
|
||||
(tbl3 cross join tbl4) same;
|
||||
\d+ view_of_joins
|
||||
View "testviewschm2.view_of_joins"
|
||||
Column | Type | Collation | Nullable | Default | Storage | Description
|
||||
--------+---------+-----------+----------+---------+---------+-------------
|
||||
a | integer | | | | plain |
|
||||
b | integer | | | | plain |
|
||||
c | integer | | | | plain |
|
||||
d | integer | | | | plain |
|
||||
e | integer | | | | plain |
|
||||
f | integer | | | | plain |
|
||||
g | integer | | | | plain |
|
||||
h | integer | | | | plain |
|
||||
View definition:
|
||||
SELECT ss.a,
|
||||
ss.b,
|
||||
ss.c,
|
||||
ss.d,
|
||||
same.e,
|
||||
same.f,
|
||||
same.g,
|
||||
same.h
|
||||
FROM ( SELECT same_1.a,
|
||||
same_1.b,
|
||||
same_1.c,
|
||||
same_1.d
|
||||
FROM (tbl1
|
||||
CROSS JOIN tbl2) same_1) ss,
|
||||
(tbl3
|
||||
CROSS JOIN tbl4) same;
|
||||
|
||||
-- Test view decompilation in the face of column addition/deletion/renaming
|
||||
create table tt2 (a int, b int, c int);
|
||||
create table tt3 (ax int8, b int2, c numeric);
|
||||
@ -1747,7 +1782,7 @@ drop cascades to view aliased_view_2
|
||||
drop cascades to view aliased_view_3
|
||||
drop cascades to view aliased_view_4
|
||||
DROP SCHEMA testviewschm2 CASCADE;
|
||||
NOTICE: drop cascades to 62 other objects
|
||||
NOTICE: drop cascades to 63 other objects
|
||||
DETAIL: drop cascades to table t1
|
||||
drop cascades to view temporal1
|
||||
drop cascades to view temporal2
|
||||
@ -1771,6 +1806,7 @@ drop cascades to view mysecview4
|
||||
drop cascades to view unspecified_types
|
||||
drop cascades to table tt1
|
||||
drop cascades to table tx1
|
||||
drop cascades to view view_of_joins
|
||||
drop cascades to table tt2
|
||||
drop cascades to table tt3
|
||||
drop cascades to table tt4
|
||||
|
@ -319,6 +319,15 @@ ALTER TABLE tmp1 RENAME TO tx1;
|
||||
\d+ aliased_view_3
|
||||
\d+ aliased_view_4
|
||||
|
||||
-- Test aliasing of joins
|
||||
|
||||
create view view_of_joins as
|
||||
select * from
|
||||
(select * from (tbl1 cross join tbl2) same) ss,
|
||||
(tbl3 cross join tbl4) same;
|
||||
|
||||
\d+ view_of_joins
|
||||
|
||||
-- Test view decompilation in the face of column addition/deletion/renaming
|
||||
|
||||
create table tt2 (a int, b int, c int);
|
||||
|
Reference in New Issue
Block a user