[COMMITTERS] pgsql: Ensure that pg_get_ruledef()'s output matchespg_get_viewdef()'s

Поиск
Список
Период
Сортировка
От Tom Lane
Тема [COMMITTERS] pgsql: Ensure that pg_get_ruledef()'s output matchespg_get_viewdef()'s
Дата
Msg-id E1dZiqn-0007fo-0i@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Ensure that pg_get_ruledef()'s output matches pg_get_viewdef()'s.

Various cases involving renaming of view columns are handled by having
make_viewdef pass down the view's current relation tupledesc to
get_query_def, which then takes care to use the column names from the
tupledesc for the output column names of the SELECT.  For some reason
though, we'd missed teaching make_ruledef to do similarly when it is
printing an ON SELECT rule, even though this is exactly the same case.
The results from pg_get_ruledef would then be different and arguably wrong.
In particular, this breaks pre-v10 versions of pg_dump, which in some
situations would define views by means of emitting a CREATE RULE ... ON
SELECT command.  Third-party tools might not be happy either.

In passing, clean up some crufty code in make_viewdef; we'd apparently
modernized the equivalent code in make_ruledef somewhere along the way,
and missed this copy.

Per report from Gilles Darold.  Back-patch to all supported versions.

Discussion: https://postgr.es/m/ec05659a-40ff-4510-fc45-ca9d965d0838@dalibo.com

Branch
------
REL9_6_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/3a07ba128581dac2f5e6b3eb0b568e2cb09dba33

Modified Files
--------------
src/backend/utils/adt/ruleutils.c         | 25 ++++++++++++++++++++-----
src/test/regress/expected/create_view.out | 29 +++++++++++++++++++++++++++++
src/test/regress/sql/create_view.sql      | 11 +++++++++++
3 files changed, 60 insertions(+), 5 deletions(-)


В списке pgsql-committers по дате отправления:

Предыдущее
От: Tom Lane
Дата:
Сообщение: [COMMITTERS] pgsql: Be more consistent about errors for opfamily member lookupfailu
Следующее
От: Robert Haas
Дата:
Сообщение: [COMMITTERS] pgsql: When WCOs are present,disable direct foreign table modification