pgsql: Make viewquery a copy in rewriteTargetView()

Поиск
Список
Период
Сортировка
От Stephen Frost
Тема pgsql: Make viewquery a copy in rewriteTargetView()
Дата
Msg-id E1aB2Ue-0002Dk-9D@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Make viewquery a copy in rewriteTargetView()

Rather than expect the Query returned by get_view_query() to be
read-only and then copy bits and pieces of it out, simply copy the
entire structure when we get it.  This addresses an issue where
AcquireRewriteLocks, which is called by acquireLocksOnSubLinks(),
scribbles on the parsetree passed in, which was actually an entry
in relcache, leading to segfaults with certain view definitions.
This also future-proofs us a bit for anyone adding more code to this
path.

The acquireLocksOnSubLinks() was added in commit c3e0ddd40.

Back-patch to 9.3 as that commit was.

Branch
------
REL9_5_STABLE

Details
-------
http://git.postgresql.org/pg/commitdiff/496943ec2b6de0f22cd9e18f673e13635b5972ef

Modified Files
--------------
src/backend/rewrite/rewriteHandler.c          |   34 ++++++++-----
src/test/regress/expected/updatable_views.out |   67 +++++++++++++++++++++++++
src/test/regress/sql/updatable_views.sql      |   44 ++++++++++++++++
3 files changed, 133 insertions(+), 12 deletions(-)


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

Предыдущее
От: Tom Lane
Дата:
Сообщение: pgsql: Remove silly completion for "DELETE FROM tabname ...".
Следующее
От: Stephen Frost
Дата:
Сообщение: pgsql: Make viewquery a copy in rewriteTargetView()