Small bugfix for DROP TABLE if table is self-referenced by
authorJan Wieck
Fri, 4 Feb 2000 23:45:04 +0000 (23:45 +0000)
committerJan Wieck
Fri, 4 Feb 2000 23:45:04 +0000 (23:45 +0000)
a FOREIGN KEY constraint.

Jan

src/backend/commands/trigger.c

index 04c20e1827daf639a9d5e49b9846b5bb1c1ec309..f83fd9462c297363e3310960ba6fd2dd43dd6e91 100644 (file)
@@ -7,7 +7,7 @@
  * Portions Copyright (c) 1994, Regents of the University of California
  *
  * IDENTIFICATION
- *   $Header: /cvsroot/pgsql/src/backend/commands/trigger.c,v 1.57 2000/02/04 18:49:31 wieck Exp $
+ *   $Header: /cvsroot/pgsql/src/backend/commands/trigger.c,v 1.58 2000/02/04 23:45:04 wieck Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -372,6 +372,13 @@ RelationRemoveTriggers(Relation rel)
 
    heap_endscan(tgscan);
 
+   /* ----------
+    * Need to bump it here so the following doesn't see
+    * the already deleted triggers again for a self-referencing
+    * table.
+    * ----------
+    */
+   CommandCounterIncrement();
 
    /* ----------
     * Also drop all constraint triggers referencing this relation
@@ -388,6 +395,7 @@ RelationRemoveTriggers(Relation rel)
        DropTrigStmt    stmt;
 
        pg_trigger = (Form_pg_trigger) GETSTRUCT(tup);
+
        refrel = heap_open(pg_trigger->tgrelid, NoLock);
 
        stmt.relname = pstrdup(RelationGetRelationName(refrel));