pgsql: Various cleanups for REFRESH MATERIALIZED VIEW CONCURRENTLY.

Поиск
Список
Период
Сортировка
От Kevin Grittner
Тема pgsql: Various cleanups for REFRESH MATERIALIZED VIEW CONCURRENTLY.
Дата
Msg-id E1V6MFw-0002sJ-7u@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Various cleanups for REFRESH MATERIALIZED VIEW CONCURRENTLY.

Open and lock each index before checking definition in RMVC.  The
ExclusiveLock on the related table is not viewed as sufficient to
ensure that no changes are made to the index definition, and
invalidation messages from other backends might have been missed.
Additionally, use RelationGetIndexExpressions() and check for NIL
rather than doing our own loop.

Protect against redefinition of tid and rowvar operators in RMVC.
While working on this, noticed that the fixes for bugs found during
the CF made the UPDATE statement useless, since no rows could
qualify for that treatment any more.  Ripping out code to support
the UPDATE statement simplified the operator cleanups.

Change slightly confusing local field name.

Use meaningful alias names on queries in refresh_by_match_merge().

Per concerns of raised by Andres Freund and comments and
suggestions from Noah Misch.  Some additional issues remain, which
will be addressed separately.

Branch
------
master

Details
-------
http://git.postgresql.org/pg/commitdiff/841c29c8b3be98ee30486ee245ebee782d4dedd4

Modified Files
--------------
src/backend/commands/matview.c |  113 ++++++++++++----------------------------
1 file changed, 34 insertions(+), 79 deletions(-)


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

Предыдущее
От: Tom Lane
Дата:
Сообщение: pgsql: Make sure float4in/float8in accept all standard spellings of "in
Следующее
От: Tom Lane
Дата:
Сообщение: pgsql: Simplify query_planner's API by having it return the top-level R