pgsql: Fix UPDATE/DELETE ... WHERE CURRENT OF on a table with virtual c
| От | Dean Rasheed |
|---|---|
| Тема | pgsql: Fix UPDATE/DELETE ... WHERE CURRENT OF on a table with virtual c |
| Дата | |
| Msg-id | E1wFVDa-0028wv-0D@gemulon.postgresql.org обсуждение |
| Список | pgsql-committers |
Fix UPDATE/DELETE ... WHERE CURRENT OF on a table with virtual columns. Formerly, attempting to use WHERE CURRENT OF to update or delete from a table with virtual generated columns would fail with the error "WHERE CURRENT OF on a view is not implemented". The reason was that the check preventing WHERE CURRENT OF from being used on a view was in replace_rte_variables_mutator(), which presumed that the only way it could get there was as part of rewriting a query on a view. That is no longer the case, since replace_rte_variables() is now also used to expand the virtual generated columns of a table. Fix by doing the check for WHERE CURRENT OF on a view at parse time. This is safe, since it is no longer possible for the relkind to change after the query is parsed (as of b23cd185f). Reported-by: Satyanarayana Narlapuram <satyanarlapuram@gmail.com> Author: Satyanarayana Narlapuram <satyanarlapuram@gmail.com> Author: Dean Rasheed <dean.a.rasheed@gmail.com> Discussion: https://postgr.es/m/CAHg+QDc_TwzSgb=B_QgNLt3mvZdmRK23rLb+RkanSQkDF40GjA@mail.gmail.com Backpatch-through: 18 Branch ------ REL_18_STABLE Details ------- https://git.postgresql.org/pg/commitdiff/f3d03fbd5d017c8e8e42a3b3bcca696cfd94a8c3 Modified Files -------------- src/backend/parser/analyze.c | 16 +++++++++++++ src/backend/rewrite/rewriteManip.c | 19 ---------------- src/test/regress/expected/generated_virtual.out | 30 +++++++++++++++++++++++++ src/test/regress/expected/portals.out | 11 +++++++++ src/test/regress/sql/generated_virtual.sql | 15 +++++++++++++ src/test/regress/sql/portals.sql | 5 +++++ 6 files changed, 77 insertions(+), 19 deletions(-)
В списке pgsql-committers по дате отправления: