• Alvaro Herrera's avatar
    Fix detaching partitions with cloned row triggers · afccd76f
    Alvaro Herrera authored
    When a partition is detached, any triggers that had been cloned from its
    parent were not properly disentangled from its parent triggers.
    This resulted in triggers that could not be dropped because they
    depended on the trigger in the trigger in the no-longer-parent table:
      ALTER TABLE t DETACH PARTITION t1;
      DROP TRIGGER trig ON t1;
        ERROR:  cannot drop trigger trig on table t1 because trigger trig on table t requires it
        HINT:  You can drop trigger trig on table t instead.
    
    Moreover the table can no longer be re-attached to its parent, because
    the trigger name is already taken:
      ALTER TABLE t ATTACH PARTITION t1 FOR VALUES FROM (1)TO(2);
        ERROR:  trigger "trig" for relation "t1" already exists
    
    The former is a bug introduced in commit 86f57594.  (The latter is
    not necessarily a bug, but it makes the bug more uncomfortable.)
    
    To avoid the complexity that would be needed to tell whether the trigger
    has a local definition that has to be merged with the one coming from
    the parent table, establish the behavior that the trigger is removed
    when the table is detached.
    
    Backpatch to pg11.
    
    Author: Justin Pryzby <pryzby@telsasoft.com>
    Reviewed-by: default avatarAmit Langote <amitlangote09@gmail.com>
    Reviewed-by: default avatarÁlvaro Herrera <alvherre@alvh.no-ip.org>
    Discussion: https://www.postgresql.org/message-id/flat/20200408152412.GZ2228@telsasoft.com
    afccd76f
triggers.out 135 KB