Commit 9e6104c6 authored by Robert Haas's avatar Robert Haas

Prohibit transition tables on views and foreign tables.

Thomas Munro, per off-list report from Prabhat Sabu.  Changes
to the message wording for consistency with the existing
relkind check for partitioned tables by me.

Discussion: http://postgr.es/m/CAEepm=2xJFFpGM+N=gpWx-9Nft2q1oaFZX07_y23AHCrJQLt0g@mail.gmail.com
parent 29fd3d9d
...@@ -361,6 +361,20 @@ CreateTrigger(CreateTrigStmt *stmt, const char *queryString, ...@@ -361,6 +361,20 @@ CreateTrigger(CreateTrigStmt *stmt, const char *queryString,
RelationGetRelationName(rel)), RelationGetRelationName(rel)),
errdetail("Triggers on partitioned tables cannot have transition tables."))); errdetail("Triggers on partitioned tables cannot have transition tables.")));
if (rel->rd_rel->relkind == RELKIND_FOREIGN_TABLE)
ereport(ERROR,
(errcode(ERRCODE_WRONG_OBJECT_TYPE),
errmsg("\"%s\" is a foreign table",
RelationGetRelationName(rel)),
errdetail("Triggers on foreign tables cannot have transition tables.")));
if (rel->rd_rel->relkind == RELKIND_VIEW)
ereport(ERROR,
(errcode(ERRCODE_WRONG_OBJECT_TYPE),
errmsg("\"%s\" is a view",
RelationGetRelationName(rel)),
errdetail("Triggers on views cannot have transition tables.")));
if (stmt->timing != TRIGGER_TYPE_AFTER) if (stmt->timing != TRIGGER_TYPE_AFTER)
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_INVALID_OBJECT_DEFINITION), (errcode(ERRCODE_INVALID_OBJECT_DEFINITION),
......
...@@ -1269,6 +1269,13 @@ CREATE TRIGGER trigtest_after_stmt AFTER INSERT OR UPDATE OR DELETE ...@@ -1269,6 +1269,13 @@ CREATE TRIGGER trigtest_after_stmt AFTER INSERT OR UPDATE OR DELETE
ON foreign_schema.foreign_table_1 ON foreign_schema.foreign_table_1
FOR EACH STATEMENT FOR EACH STATEMENT
EXECUTE PROCEDURE dummy_trigger(); EXECUTE PROCEDURE dummy_trigger();
CREATE TRIGGER trigtest_after_stmt_tt AFTER INSERT OR UPDATE OR DELETE -- ERROR
ON foreign_schema.foreign_table_1
REFERENCING NEW TABLE AS new_table
FOR EACH STATEMENT
EXECUTE PROCEDURE dummy_trigger();
ERROR: "foreign_table_1" is a foreign table
DETAIL: Triggers on foreign tables cannot have transition tables.
CREATE TRIGGER trigtest_before_row BEFORE INSERT OR UPDATE OR DELETE CREATE TRIGGER trigtest_before_row BEFORE INSERT OR UPDATE OR DELETE
ON foreign_schema.foreign_table_1 ON foreign_schema.foreign_table_1
FOR EACH ROW FOR EACH ROW
......
...@@ -1785,9 +1785,24 @@ drop trigger my_trigger on my_table_42; ...@@ -1785,9 +1785,24 @@ drop trigger my_trigger on my_table_42;
create trigger my_trigger after update on my_table_42 referencing old table as old_table create trigger my_trigger after update on my_table_42 referencing old table as old_table
for each statement execute procedure my_trigger_function(); for each statement execute procedure my_trigger_function();
drop trigger my_trigger on my_table_42; drop trigger my_trigger on my_table_42;
drop function my_trigger_function();
drop table my_table_42; drop table my_table_42;
drop table my_table; drop table my_table;
-- --
-- Verify that triggers with transition tables are not allowed on
-- views
--
create table my_table (i int);
create view my_view as select * from my_table;
create function my_trigger_function() returns trigger as $$ begin end; $$ language plpgsql;
create trigger my_trigger after update on my_view referencing old table as old_table
for each statement execute procedure my_trigger_function();
ERROR: "my_view" is a view
DETAIL: Triggers on views cannot have transition tables.
drop function my_trigger_function();
drop view my_view;
drop table my_table;
--
-- Verify that per-statement triggers are fired for partitioned tables -- Verify that per-statement triggers are fired for partitioned tables
-- --
create table parted_stmt_trig (a int) partition by list (a); create table parted_stmt_trig (a int) partition by list (a);
......
...@@ -527,6 +527,12 @@ ON foreign_schema.foreign_table_1 ...@@ -527,6 +527,12 @@ ON foreign_schema.foreign_table_1
FOR EACH STATEMENT FOR EACH STATEMENT
EXECUTE PROCEDURE dummy_trigger(); EXECUTE PROCEDURE dummy_trigger();
CREATE TRIGGER trigtest_after_stmt_tt AFTER INSERT OR UPDATE OR DELETE -- ERROR
ON foreign_schema.foreign_table_1
REFERENCING NEW TABLE AS new_table
FOR EACH STATEMENT
EXECUTE PROCEDURE dummy_trigger();
CREATE TRIGGER trigtest_before_row BEFORE INSERT OR UPDATE OR DELETE CREATE TRIGGER trigtest_before_row BEFORE INSERT OR UPDATE OR DELETE
ON foreign_schema.foreign_table_1 ON foreign_schema.foreign_table_1
FOR EACH ROW FOR EACH ROW
......
...@@ -1261,9 +1261,24 @@ drop trigger my_trigger on my_table_42; ...@@ -1261,9 +1261,24 @@ drop trigger my_trigger on my_table_42;
create trigger my_trigger after update on my_table_42 referencing old table as old_table create trigger my_trigger after update on my_table_42 referencing old table as old_table
for each statement execute procedure my_trigger_function(); for each statement execute procedure my_trigger_function();
drop trigger my_trigger on my_table_42; drop trigger my_trigger on my_table_42;
drop function my_trigger_function();
drop table my_table_42; drop table my_table_42;
drop table my_table; drop table my_table;
--
-- Verify that triggers with transition tables are not allowed on
-- views
--
create table my_table (i int);
create view my_view as select * from my_table;
create function my_trigger_function() returns trigger as $$ begin end; $$ language plpgsql;
create trigger my_trigger after update on my_view referencing old table as old_table
for each statement execute procedure my_trigger_function();
drop function my_trigger_function();
drop view my_view;
drop table my_table;
-- --
-- Verify that per-statement triggers are fired for partitioned tables -- Verify that per-statement triggers are fired for partitioned tables
-- --
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment