*
*
* IDENTIFICATION
- * $Header: /cvsroot/pgsql/src/backend/commands/tablecmds.c,v 1.47 2002/10/19 02:25:51 momjian Exp $
+ * $Header: /cvsroot/pgsql/src/backend/commands/tablecmds.c,v 1.48 2002/10/19 03:01:09 momjian Exp $
*
*-------------------------------------------------------------------------
*/
colDefChild->inhcount = 1;
colDefChild->is_local = false;
- /* we only need direct inheritors */
- children = find_inheritance_children(myrelid);
+ /* this routine is actually in the planner */
+ children = find_all_inheritors(myrelid);
/*
- * If the child has a column with same name and type,
- * increment its attinhcount and continue. If it has
- * different type, abort. If it doesn't have a column
- * with the same name, add it.
+ * find_all_inheritors does the recursive search of the
+ * inheritance hierarchy, so all we have to do is process all of
+ * the relids in the list that it returns.
*/
foreach(child, children)
{
Oid childrelid = lfirsti(child);
- HeapTuple tuple;
- Form_pg_attribute childatt;
if (childrelid == myrelid)
continue;
- attrdesc = heap_openr(AttributeRelationName, RowExclusiveLock);
- tuple = SearchSysCacheCopyAttName(childrelid, colDef->colname);
- if (!HeapTupleIsValid(tuple))
- {
- heap_close(attrdesc, RowExclusiveLock);
- AlterTableAddColumn(childrelid, false, true, colDefChild);
- continue;
- }
- childatt = (Form_pg_attribute) GETSTRUCT(tuple);
-
- typeTuple = typenameType(colDef->typename);
- tform = (Form_pg_type) GETSTRUCT(typeTuple);
-
- if (HeapTupleGetOid(typeTuple) != childatt->atttypid ||
- colDef->typename->typmod != childatt->atttypmod)
- elog(ERROR, "ALTER TABLE: child table %u has different "
- "type for column \"%s\"",
- childrelid, colDef->colname);
-
- childatt->attinhcount++;
- simple_heap_update(attrdesc, &tuple->t_self, tuple);
- CatalogUpdateIndexes(attrdesc, tuple);
-
- elog(NOTICE, "ALTER TABLE: merging definition of column "
- "\"%s\" for child %u", colDef->colname, childrelid);
-
- heap_close(attrdesc, RowExclusiveLock);
- heap_freetuple(tuple);
- ReleaseSysCache(typeTuple);
+ AlterTableAddColumn(childrelid, false, true, colDefChild);
}
}
else