diff options
author | Tom Lane <tgl@sss.pgh.pa.us> | 2016-11-07 12:08:19 -0500 |
---|---|---|
committer | Tom Lane <tgl@sss.pgh.pa.us> | 2016-11-07 12:08:19 -0500 |
commit | e2f5cd9cf5588cc37f665fb2ca061898b5c73f2a (patch) | |
tree | 403774282daa86cdcf81c869210d99df222b9675 | |
parent | e98c3ab2bd65f0e78bce20ace477eeed76b87345 (diff) | |
download | postgresql-e2f5cd9cf5588cc37f665fb2ca061898b5c73f2a.tar.gz postgresql-e2f5cd9cf5588cc37f665fb2ca061898b5c73f2a.zip |
Band-aid fix for incorrect use of view options as StdRdOptions.
We really ought to make StdRdOptions and the other decoded forms of
reloptions self-identifying, but for the moment, assume that only plain
relations could possibly be user_catalog_tables. Fixes problem with bogus
"ON CONFLICT is not supported on table ... used as a catalog table" error
when target is a view with cascade option.
Discussion: <26681.1477940227@sss.pgh.pa.us>
-rw-r--r-- | src/include/utils/rel.h | 3 | ||||
-rw-r--r-- | src/test/regress/expected/insert_conflict.out | 24 | ||||
-rw-r--r-- | src/test/regress/sql/insert_conflict.sql | 18 |
3 files changed, 44 insertions, 1 deletions
diff --git a/src/include/utils/rel.h b/src/include/utils/rel.h index 8a55a090b61..755badff0c9 100644 --- a/src/include/utils/rel.h +++ b/src/include/utils/rel.h @@ -253,7 +253,8 @@ typedef struct StdRdOptions * from the pov of logical decoding. Note multiple eval or argument! */ #define RelationIsUsedAsCatalogTable(relation) \ - ((relation)->rd_options ? \ + ((relation)->rd_rel->relkind == RELKIND_RELATION && \ + (relation)->rd_options ? \ ((StdRdOptions *) (relation)->rd_options)->user_catalog_table : false) diff --git a/src/test/regress/expected/insert_conflict.out b/src/test/regress/expected/insert_conflict.out index b2e63ab8275..faef1e74688 100644 --- a/src/test/regress/expected/insert_conflict.out +++ b/src/test/regress/expected/insert_conflict.out @@ -469,6 +469,30 @@ on conflict (b) where coalesce(a, 1) > 0 do nothing; insert into insertconflict values (1, 2) on conflict (b) where coalesce(a, 1) > 1 do nothing; drop table insertconflict; +-- +-- test insertion through view +-- +create table insertconflict (f1 int primary key, f2 text); +create view insertconflictv as + select * from insertconflict with cascaded check option; +insert into insertconflictv values (1,'foo') + on conflict (f1) do update set f2 = excluded.f2; +select * from insertconflict; + f1 | f2 +----+----- + 1 | foo +(1 row) + +insert into insertconflictv values (1,'bar') + on conflict (f1) do update set f2 = excluded.f2; +select * from insertconflict; + f1 | f2 +----+----- + 1 | bar +(1 row) + +drop view insertconflictv; +drop table insertconflict; -- ****************************************************************** -- * * -- * Test inheritance (example taken from tutorial) * diff --git a/src/test/regress/sql/insert_conflict.sql b/src/test/regress/sql/insert_conflict.sql index 81c4a7ca4ba..116cf763f95 100644 --- a/src/test/regress/sql/insert_conflict.sql +++ b/src/test/regress/sql/insert_conflict.sql @@ -283,6 +283,24 @@ on conflict (b) where coalesce(a, 1) > 1 do nothing; drop table insertconflict; +-- +-- test insertion through view +-- + +create table insertconflict (f1 int primary key, f2 text); +create view insertconflictv as + select * from insertconflict with cascaded check option; + +insert into insertconflictv values (1,'foo') + on conflict (f1) do update set f2 = excluded.f2; +select * from insertconflict; +insert into insertconflictv values (1,'bar') + on conflict (f1) do update set f2 = excluded.f2; +select * from insertconflict; + +drop view insertconflictv; +drop table insertconflict; + -- ****************************************************************** -- * * |