Commit 8febfd18 authored by Michael Paquier's avatar Michael Paquier

Switch to multi-inserts when registering dependencies for many code paths

This commit improves the dependency registrations by taking advantage of
the preliminary work done in 63110c62, to group together the insertion
of dependencies of the same type to pg_depend.  With the current layer
of routines available, and as only dependencies of the same type can be
grouped, there are code paths still doing more than one multi-insert
when it is necessary to register dependencies of multiple types
(constraint and index creation are two cases doing that).

While on it, this refactors some of the code to use ObjectAddressSet()
when manipulating object addresses.

Author: Daniel Gustafsson, Michael Paquier
Reviewed-by: Andres Freund, Álvaro Herrera
Discussion: https://postgr.es/m/20200807061619.GA23955@paquier.xyz
parent 11b80d90
...@@ -1428,15 +1428,9 @@ heap_create_with_catalog(const char *relname, ...@@ -1428,15 +1428,9 @@ heap_create_with_catalog(const char *relname,
{ {
ObjectAddress myself, ObjectAddress myself,
referenced; referenced;
ObjectAddresses *addrs;
myself.classId = RelationRelationId; ObjectAddressSet(myself, RelationRelationId, relid);
myself.objectId = relid;
myself.objectSubId = 0;
referenced.classId = NamespaceRelationId;
referenced.objectId = relnamespace;
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
recordDependencyOnOwner(RelationRelationId, relid, ownerid); recordDependencyOnOwner(RelationRelationId, relid, ownerid);
...@@ -1444,12 +1438,15 @@ heap_create_with_catalog(const char *relname, ...@@ -1444,12 +1438,15 @@ heap_create_with_catalog(const char *relname,
recordDependencyOnCurrentExtension(&myself, false); recordDependencyOnCurrentExtension(&myself, false);
addrs = new_object_addresses();
ObjectAddressSet(referenced, NamespaceRelationId, relnamespace);
add_exact_object_address(&referenced, addrs);
if (reloftypeid) if (reloftypeid)
{ {
referenced.classId = TypeRelationId; ObjectAddressSet(referenced, TypeRelationId, reloftypeid);
referenced.objectId = reloftypeid; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
} }
/* /*
...@@ -1462,11 +1459,12 @@ heap_create_with_catalog(const char *relname, ...@@ -1462,11 +1459,12 @@ heap_create_with_catalog(const char *relname,
if (relkind == RELKIND_RELATION || if (relkind == RELKIND_RELATION ||
relkind == RELKIND_MATVIEW) relkind == RELKIND_MATVIEW)
{ {
referenced.classId = AccessMethodRelationId; ObjectAddressSet(referenced, AccessMethodRelationId, accessmtd);
referenced.objectId = accessmtd; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
} }
record_object_address_dependencies(&myself, addrs, DEPENDENCY_NORMAL);
free_object_addresses(addrs);
} }
/* Post creation hook for new relation */ /* Post creation hook for new relation */
...@@ -3574,6 +3572,7 @@ StorePartitionKey(Relation rel, ...@@ -3574,6 +3572,7 @@ StorePartitionKey(Relation rel,
bool nulls[Natts_pg_partitioned_table]; bool nulls[Natts_pg_partitioned_table];
ObjectAddress myself; ObjectAddress myself;
ObjectAddress referenced; ObjectAddress referenced;
ObjectAddresses *addrs;
Assert(rel->rd_rel->relkind == RELKIND_PARTITIONED_TABLE); Assert(rel->rd_rel->relkind == RELKIND_PARTITIONED_TABLE);
...@@ -3617,31 +3616,27 @@ StorePartitionKey(Relation rel, ...@@ -3617,31 +3616,27 @@ StorePartitionKey(Relation rel,
table_close(pg_partitioned_table, RowExclusiveLock); table_close(pg_partitioned_table, RowExclusiveLock);
/* Mark this relation as dependent on a few things as follows */ /* Mark this relation as dependent on a few things as follows */
myself.classId = RelationRelationId; addrs = new_object_addresses();
myself.objectId = RelationGetRelid(rel); ObjectAddressSet(myself, RelationRelationId, RelationGetRelid(rel));
myself.objectSubId = 0;
/* Operator class and collation per key column */ /* Operator class and collation per key column */
for (i = 0; i < partnatts; i++) for (i = 0; i < partnatts; i++)
{ {
referenced.classId = OperatorClassRelationId; ObjectAddressSet(referenced, OperatorClassRelationId, partopclass[i]);
referenced.objectId = partopclass[i]; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
/* The default collation is pinned, so don't bother recording it */ /* The default collation is pinned, so don't bother recording it */
if (OidIsValid(partcollation[i]) && if (OidIsValid(partcollation[i]) &&
partcollation[i] != DEFAULT_COLLATION_OID) partcollation[i] != DEFAULT_COLLATION_OID)
{ {
referenced.classId = CollationRelationId; ObjectAddressSet(referenced, CollationRelationId, partcollation[i]);
referenced.objectId = partcollation[i]; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
} }
} }
record_object_address_dependencies(&myself, addrs, DEPENDENCY_NORMAL);
free_object_addresses(addrs);
/* /*
* The partitioning columns are made internally dependent on the table, * The partitioning columns are made internally dependent on the table,
* because we cannot drop any of them without dropping the whole table. * because we cannot drop any of them without dropping the whole table.
...@@ -3653,10 +3648,8 @@ StorePartitionKey(Relation rel, ...@@ -3653,10 +3648,8 @@ StorePartitionKey(Relation rel,
if (partattrs[i] == 0) if (partattrs[i] == 0)
continue; /* ignore expressions here */ continue; /* ignore expressions here */
referenced.classId = RelationRelationId; ObjectAddressSubSet(referenced, RelationRelationId,
referenced.objectId = RelationGetRelid(rel); RelationGetRelid(rel), partattrs[i]);
referenced.objectSubId = partattrs[i];
recordDependencyOn(&referenced, &myself, DEPENDENCY_INTERNAL); recordDependencyOn(&referenced, &myself, DEPENDENCY_INTERNAL);
} }
......
...@@ -1018,6 +1018,7 @@ index_create(Relation heapRelation, ...@@ -1018,6 +1018,7 @@ index_create(Relation heapRelation,
{ {
ObjectAddress myself, ObjectAddress myself,
referenced; referenced;
ObjectAddresses *addrs;
ObjectAddressSet(myself, RelationRelationId, indexRelationId); ObjectAddressSet(myself, RelationRelationId, indexRelationId);
...@@ -1054,6 +1055,8 @@ index_create(Relation heapRelation, ...@@ -1054,6 +1055,8 @@ index_create(Relation heapRelation,
{ {
bool have_simple_col = false; bool have_simple_col = false;
addrs = new_object_addresses();
/* Create auto dependencies on simply-referenced columns */ /* Create auto dependencies on simply-referenced columns */
for (i = 0; i < indexInfo->ii_NumIndexAttrs; i++) for (i = 0; i < indexInfo->ii_NumIndexAttrs; i++)
{ {
...@@ -1062,7 +1065,7 @@ index_create(Relation heapRelation, ...@@ -1062,7 +1065,7 @@ index_create(Relation heapRelation,
ObjectAddressSubSet(referenced, RelationRelationId, ObjectAddressSubSet(referenced, RelationRelationId,
heapRelationId, heapRelationId,
indexInfo->ii_IndexAttrNumbers[i]); indexInfo->ii_IndexAttrNumbers[i]);
recordDependencyOn(&myself, &referenced, DEPENDENCY_AUTO); add_exact_object_address(&referenced, addrs);
have_simple_col = true; have_simple_col = true;
} }
} }
...@@ -1077,8 +1080,11 @@ index_create(Relation heapRelation, ...@@ -1077,8 +1080,11 @@ index_create(Relation heapRelation,
{ {
ObjectAddressSet(referenced, RelationRelationId, ObjectAddressSet(referenced, RelationRelationId,
heapRelationId); heapRelationId);
recordDependencyOn(&myself, &referenced, DEPENDENCY_AUTO); add_exact_object_address(&referenced, addrs);
} }
record_object_address_dependencies(&myself, addrs, DEPENDENCY_AUTO);
free_object_addresses(addrs);
} }
/* /*
...@@ -1096,7 +1102,11 @@ index_create(Relation heapRelation, ...@@ -1096,7 +1102,11 @@ index_create(Relation heapRelation,
recordDependencyOn(&myself, &referenced, DEPENDENCY_PARTITION_SEC); recordDependencyOn(&myself, &referenced, DEPENDENCY_PARTITION_SEC);
} }
/* placeholder for normal dependencies */
addrs = new_object_addresses();
/* Store dependency on collations */ /* Store dependency on collations */
/* The default collation is pinned, so don't bother recording it */ /* The default collation is pinned, so don't bother recording it */
for (i = 0; i < indexInfo->ii_NumIndexKeyAttrs; i++) for (i = 0; i < indexInfo->ii_NumIndexKeyAttrs; i++)
{ {
...@@ -1105,7 +1115,7 @@ index_create(Relation heapRelation, ...@@ -1105,7 +1115,7 @@ index_create(Relation heapRelation,
{ {
ObjectAddressSet(referenced, CollationRelationId, ObjectAddressSet(referenced, CollationRelationId,
collationObjectId[i]); collationObjectId[i]);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
} }
...@@ -1113,9 +1123,12 @@ index_create(Relation heapRelation, ...@@ -1113,9 +1123,12 @@ index_create(Relation heapRelation,
for (i = 0; i < indexInfo->ii_NumIndexKeyAttrs; i++) for (i = 0; i < indexInfo->ii_NumIndexKeyAttrs; i++)
{ {
ObjectAddressSet(referenced, OperatorClassRelationId, classObjectId[i]); ObjectAddressSet(referenced, OperatorClassRelationId, classObjectId[i]);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
record_object_address_dependencies(&myself, addrs, DEPENDENCY_NORMAL);
free_object_addresses(addrs);
/* Store dependencies on anything mentioned in index expressions */ /* Store dependencies on anything mentioned in index expressions */
if (indexInfo->ii_Expressions) if (indexInfo->ii_Expressions)
{ {
......
...@@ -105,6 +105,7 @@ AggregateCreate(const char *aggName, ...@@ -105,6 +105,7 @@ AggregateCreate(const char *aggName,
int i; int i;
ObjectAddress myself, ObjectAddress myself,
referenced; referenced;
ObjectAddresses *addrs;
AclResult aclresult; AclResult aclresult;
/* sanity checks (caller should have caught these) */ /* sanity checks (caller should have caught these) */
...@@ -741,66 +742,70 @@ AggregateCreate(const char *aggName, ...@@ -741,66 +742,70 @@ AggregateCreate(const char *aggName,
* way. * way.
*/ */
addrs = new_object_addresses();
/* Depends on transition function */ /* Depends on transition function */
ObjectAddressSet(referenced, ProcedureRelationId, transfn); ObjectAddressSet(referenced, ProcedureRelationId, transfn);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
/* Depends on final function, if any */ /* Depends on final function, if any */
if (OidIsValid(finalfn)) if (OidIsValid(finalfn))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, finalfn); ObjectAddressSet(referenced, ProcedureRelationId, finalfn);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* Depends on combine function, if any */ /* Depends on combine function, if any */
if (OidIsValid(combinefn)) if (OidIsValid(combinefn))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, combinefn); ObjectAddressSet(referenced, ProcedureRelationId, combinefn);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* Depends on serialization function, if any */ /* Depends on serialization function, if any */
if (OidIsValid(serialfn)) if (OidIsValid(serialfn))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, serialfn); ObjectAddressSet(referenced, ProcedureRelationId, serialfn);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* Depends on deserialization function, if any */ /* Depends on deserialization function, if any */
if (OidIsValid(deserialfn)) if (OidIsValid(deserialfn))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, deserialfn); ObjectAddressSet(referenced, ProcedureRelationId, deserialfn);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* Depends on forward transition function, if any */ /* Depends on forward transition function, if any */
if (OidIsValid(mtransfn)) if (OidIsValid(mtransfn))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, mtransfn); ObjectAddressSet(referenced, ProcedureRelationId, mtransfn);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* Depends on inverse transition function, if any */ /* Depends on inverse transition function, if any */
if (OidIsValid(minvtransfn)) if (OidIsValid(minvtransfn))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, minvtransfn); ObjectAddressSet(referenced, ProcedureRelationId, minvtransfn);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* Depends on final function, if any */ /* Depends on final function, if any */
if (OidIsValid(mfinalfn)) if (OidIsValid(mfinalfn))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, mfinalfn); ObjectAddressSet(referenced, ProcedureRelationId, mfinalfn);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* Depends on sort operator, if any */ /* Depends on sort operator, if any */
if (OidIsValid(sortop)) if (OidIsValid(sortop))
{ {
ObjectAddressSet(referenced, OperatorRelationId, sortop); ObjectAddressSet(referenced, OperatorRelationId, sortop);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
record_object_address_dependencies(&myself, addrs, DEPENDENCY_NORMAL);
free_object_addresses(addrs);
return myself; return myself;
} }
......
...@@ -50,6 +50,7 @@ CastCreate(Oid sourcetypeid, Oid targettypeid, Oid funcid, char castcontext, ...@@ -50,6 +50,7 @@ CastCreate(Oid sourcetypeid, Oid targettypeid, Oid funcid, char castcontext,
bool nulls[Natts_pg_cast]; bool nulls[Natts_pg_cast];
ObjectAddress myself, ObjectAddress myself,
referenced; referenced;
ObjectAddresses *addrs;
relation = table_open(CastRelationId, RowExclusiveLock); relation = table_open(CastRelationId, RowExclusiveLock);
...@@ -83,32 +84,29 @@ CastCreate(Oid sourcetypeid, Oid targettypeid, Oid funcid, char castcontext, ...@@ -83,32 +84,29 @@ CastCreate(Oid sourcetypeid, Oid targettypeid, Oid funcid, char castcontext,
CatalogTupleInsert(relation, tuple); CatalogTupleInsert(relation, tuple);
addrs = new_object_addresses();
/* make dependency entries */ /* make dependency entries */
myself.classId = CastRelationId; ObjectAddressSet(myself, CastRelationId, castid);
myself.objectId = castid;
myself.objectSubId = 0;
/* dependency on source type */ /* dependency on source type */
referenced.classId = TypeRelationId; ObjectAddressSet(referenced, TypeRelationId, sourcetypeid);
referenced.objectId = sourcetypeid; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, behavior);
/* dependency on target type */ /* dependency on target type */
referenced.classId = TypeRelationId; ObjectAddressSet(referenced, TypeRelationId, targettypeid);
referenced.objectId = targettypeid; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, behavior);
/* dependency on function */ /* dependency on function */
if (OidIsValid(funcid)) if (OidIsValid(funcid))
{ {
referenced.classId = ProcedureRelationId; ObjectAddressSet(referenced, ProcedureRelationId, funcid);
referenced.objectId = funcid; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, behavior);
} }
record_object_address_dependencies(&myself, addrs, behavior);
free_object_addresses(addrs);
/* dependency on extension */ /* dependency on extension */
recordDependencyOnCurrentExtension(&myself, false); recordDependencyOnCurrentExtension(&myself, false);
......
...@@ -91,6 +91,8 @@ CreateConstraintEntry(const char *constraintName, ...@@ -91,6 +91,8 @@ CreateConstraintEntry(const char *constraintName,
NameData cname; NameData cname;
int i; int i;
ObjectAddress conobject; ObjectAddress conobject;
ObjectAddresses *addrs_auto;
ObjectAddresses *addrs_normal;
conDesc = table_open(ConstraintRelationId, RowExclusiveLock); conDesc = table_open(ConstraintRelationId, RowExclusiveLock);
...@@ -227,6 +229,9 @@ CreateConstraintEntry(const char *constraintName, ...@@ -227,6 +229,9 @@ CreateConstraintEntry(const char *constraintName,
table_close(conDesc, RowExclusiveLock); table_close(conDesc, RowExclusiveLock);
/* Handle set of auto dependencies */
addrs_auto = new_object_addresses();
if (OidIsValid(relId)) if (OidIsValid(relId))
{ {
/* /*
...@@ -241,13 +246,13 @@ CreateConstraintEntry(const char *constraintName, ...@@ -241,13 +246,13 @@ CreateConstraintEntry(const char *constraintName,
{ {
ObjectAddressSubSet(relobject, RelationRelationId, relId, ObjectAddressSubSet(relobject, RelationRelationId, relId,
constraintKey[i]); constraintKey[i]);
recordDependencyOn(&conobject, &relobject, DEPENDENCY_AUTO); add_exact_object_address(&relobject, addrs_auto);
} }
} }
else else
{ {
ObjectAddressSet(relobject, RelationRelationId, relId); ObjectAddressSet(relobject, RelationRelationId, relId);
recordDependencyOn(&conobject, &relobject, DEPENDENCY_AUTO); add_exact_object_address(&relobject, addrs_auto);
} }
} }
...@@ -259,9 +264,16 @@ CreateConstraintEntry(const char *constraintName, ...@@ -259,9 +264,16 @@ CreateConstraintEntry(const char *constraintName,
ObjectAddress domobject; ObjectAddress domobject;
ObjectAddressSet(domobject, TypeRelationId, domainId); ObjectAddressSet(domobject, TypeRelationId, domainId);
recordDependencyOn(&conobject, &domobject, DEPENDENCY_AUTO); add_exact_object_address(&domobject, addrs_auto);
} }
record_object_address_dependencies(&conobject, addrs_auto,
DEPENDENCY_AUTO);
free_object_addresses(addrs_auto);
/* Handle set of normal dependencies */
addrs_normal = new_object_addresses();
if (OidIsValid(foreignRelId)) if (OidIsValid(foreignRelId))
{ {
/* /*
...@@ -276,13 +288,13 @@ CreateConstraintEntry(const char *constraintName, ...@@ -276,13 +288,13 @@ CreateConstraintEntry(const char *constraintName,
{ {
ObjectAddressSubSet(relobject, RelationRelationId, ObjectAddressSubSet(relobject, RelationRelationId,
foreignRelId, foreignKey[i]); foreignRelId, foreignKey[i]);
recordDependencyOn(&conobject, &relobject, DEPENDENCY_NORMAL); add_exact_object_address(&relobject, addrs_normal);
} }
} }
else else
{ {
ObjectAddressSet(relobject, RelationRelationId, foreignRelId); ObjectAddressSet(relobject, RelationRelationId, foreignRelId);
recordDependencyOn(&conobject, &relobject, DEPENDENCY_NORMAL); add_exact_object_address(&relobject, addrs_normal);
} }
} }
...@@ -297,7 +309,7 @@ CreateConstraintEntry(const char *constraintName, ...@@ -297,7 +309,7 @@ CreateConstraintEntry(const char *constraintName,
ObjectAddress relobject; ObjectAddress relobject;
ObjectAddressSet(relobject, RelationRelationId, indexRelId); ObjectAddressSet(relobject, RelationRelationId, indexRelId);
recordDependencyOn(&conobject, &relobject, DEPENDENCY_NORMAL); add_exact_object_address(&relobject, addrs_normal);
} }
if (foreignNKeys > 0) if (foreignNKeys > 0)
...@@ -316,20 +328,24 @@ CreateConstraintEntry(const char *constraintName, ...@@ -316,20 +328,24 @@ CreateConstraintEntry(const char *constraintName,
for (i = 0; i < foreignNKeys; i++) for (i = 0; i < foreignNKeys; i++)
{ {
oprobject.objectId = pfEqOp[i]; oprobject.objectId = pfEqOp[i];
recordDependencyOn(&conobject, &oprobject, DEPENDENCY_NORMAL); add_exact_object_address(&oprobject, addrs_normal);
if (ppEqOp[i] != pfEqOp[i]) if (ppEqOp[i] != pfEqOp[i])
{ {
oprobject.objectId = ppEqOp[i]; oprobject.objectId = ppEqOp[i];
recordDependencyOn(&conobject, &oprobject, DEPENDENCY_NORMAL); add_exact_object_address(&oprobject, addrs_normal);
} }
if (ffEqOp[i] != pfEqOp[i]) if (ffEqOp[i] != pfEqOp[i])
{ {
oprobject.objectId = ffEqOp[i]; oprobject.objectId = ffEqOp[i];
recordDependencyOn(&conobject, &oprobject, DEPENDENCY_NORMAL); add_exact_object_address(&oprobject, addrs_normal);
} }
} }
} }
record_object_address_dependencies(&conobject, addrs_normal,
DEPENDENCY_NORMAL);
free_object_addresses(addrs_normal);
/* /*
* We don't bother to register dependencies on the exclusion operators of * We don't bother to register dependencies on the exclusion operators of
* an exclusion constraint. We assume they are members of the opclass * an exclusion constraint. We assume they are members of the opclass
......
...@@ -775,6 +775,7 @@ makeOperatorDependencies(HeapTuple tuple, bool isUpdate) ...@@ -775,6 +775,7 @@ makeOperatorDependencies(HeapTuple tuple, bool isUpdate)
Form_pg_operator oper = (Form_pg_operator) GETSTRUCT(tuple); Form_pg_operator oper = (Form_pg_operator) GETSTRUCT(tuple);
ObjectAddress myself, ObjectAddress myself,
referenced; referenced;
ObjectAddresses *addrs;
ObjectAddressSet(myself, OperatorRelationId, oper->oid); ObjectAddressSet(myself, OperatorRelationId, oper->oid);
...@@ -788,32 +789,34 @@ makeOperatorDependencies(HeapTuple tuple, bool isUpdate) ...@@ -788,32 +789,34 @@ makeOperatorDependencies(HeapTuple tuple, bool isUpdate)
deleteSharedDependencyRecordsFor(myself.classId, myself.objectId, 0); deleteSharedDependencyRecordsFor(myself.classId, myself.objectId, 0);
} }
addrs = new_object_addresses();
/* Dependency on namespace */ /* Dependency on namespace */
if (OidIsValid(oper->oprnamespace)) if (OidIsValid(oper->oprnamespace))
{ {
ObjectAddressSet(referenced, NamespaceRelationId, oper->oprnamespace); ObjectAddressSet(referenced, NamespaceRelationId, oper->oprnamespace);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* Dependency on left type */ /* Dependency on left type */
if (OidIsValid(oper->oprleft)) if (OidIsValid(oper->oprleft))
{ {
ObjectAddressSet(referenced, TypeRelationId, oper->oprleft); ObjectAddressSet(referenced, TypeRelationId, oper->oprleft);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* Dependency on right type */ /* Dependency on right type */
if (OidIsValid(oper->oprright)) if (OidIsValid(oper->oprright))
{ {
ObjectAddressSet(referenced, TypeRelationId, oper->oprright); ObjectAddressSet(referenced, TypeRelationId, oper->oprright);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* Dependency on result type */ /* Dependency on result type */
if (OidIsValid(oper->oprresult)) if (OidIsValid(oper->oprresult))
{ {
ObjectAddressSet(referenced, TypeRelationId, oper->oprresult); ObjectAddressSet(referenced, TypeRelationId, oper->oprresult);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* /*
...@@ -829,23 +832,26 @@ makeOperatorDependencies(HeapTuple tuple, bool isUpdate) ...@@ -829,23 +832,26 @@ makeOperatorDependencies(HeapTuple tuple, bool isUpdate)
if (OidIsValid(oper->oprcode)) if (OidIsValid(oper->oprcode))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, oper->oprcode); ObjectAddressSet(referenced, ProcedureRelationId, oper->oprcode);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* Dependency on restriction selectivity function */ /* Dependency on restriction selectivity function */
if (OidIsValid(oper->oprrest)) if (OidIsValid(oper->oprrest))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, oper->oprrest); ObjectAddressSet(referenced, ProcedureRelationId, oper->oprrest);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* Dependency on join selectivity function */ /* Dependency on join selectivity function */
if (OidIsValid(oper->oprjoin)) if (OidIsValid(oper->oprjoin))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, oper->oprjoin); ObjectAddressSet(referenced, ProcedureRelationId, oper->oprjoin);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
record_object_address_dependencies(&myself, addrs, DEPENDENCY_NORMAL);
free_object_addresses(addrs);
/* Dependency on owner */ /* Dependency on owner */
recordDependencyOnOwner(OperatorRelationId, oper->oid, recordDependencyOnOwner(OperatorRelationId, oper->oid,
oper->oprowner); oper->oprowner);
......
...@@ -114,6 +114,7 @@ ProcedureCreate(const char *procedureName, ...@@ -114,6 +114,7 @@ ProcedureCreate(const char *procedureName,
char *detailmsg; char *detailmsg;
int i; int i;
Oid trfid; Oid trfid;
ObjectAddresses *addrs;
/* /*
* sanity checks * sanity checks
...@@ -585,53 +586,58 @@ ProcedureCreate(const char *procedureName, ...@@ -585,53 +586,58 @@ ProcedureCreate(const char *procedureName,
if (is_update) if (is_update)
deleteDependencyRecordsFor(ProcedureRelationId, retval, true); deleteDependencyRecordsFor(ProcedureRelationId, retval, true);
addrs = new_object_addresses();
ObjectAddressSet(myself, ProcedureRelationId, retval); ObjectAddressSet(myself, ProcedureRelationId, retval);
/* dependency on namespace */ /* dependency on namespace */
ObjectAddressSet(referenced, NamespaceRelationId, procNamespace); ObjectAddressSet(referenced, NamespaceRelationId, procNamespace);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
/* dependency on implementation language */ /* dependency on implementation language */
ObjectAddressSet(referenced, LanguageRelationId, languageObjectId); ObjectAddressSet(referenced, LanguageRelationId, languageObjectId);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
/* dependency on return type */ /* dependency on return type */
ObjectAddressSet(referenced, TypeRelationId, returnType); ObjectAddressSet(referenced, TypeRelationId, returnType);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
/* dependency on transform used by return type, if any */ /* dependency on transform used by return type, if any */
if ((trfid = get_transform_oid(returnType, languageObjectId, true))) if ((trfid = get_transform_oid(returnType, languageObjectId, true)))
{ {
ObjectAddressSet(referenced, TransformRelationId, trfid); ObjectAddressSet(referenced, TransformRelationId, trfid);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
/* dependency on parameter types */ /* dependency on parameter types */
for (i = 0; i < allParamCount; i++) for (i = 0; i < allParamCount; i++)
{ {
ObjectAddressSet(referenced, TypeRelationId, allParams[i]); ObjectAddressSet(referenced, TypeRelationId, allParams[i]);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
/* dependency on transform used by parameter type, if any */ /* dependency on transform used by parameter type, if any */
if ((trfid = get_transform_oid(allParams[i], languageObjectId, true))) if ((trfid = get_transform_oid(allParams[i], languageObjectId, true)))
{ {
ObjectAddressSet(referenced, TransformRelationId, trfid); ObjectAddressSet(referenced, TransformRelationId, trfid);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
} }
/* dependency on parameter default expressions */
if (parameterDefaults)
recordDependencyOnExpr(&myself, (Node *) parameterDefaults,
NIL, DEPENDENCY_NORMAL);
/* dependency on support function, if any */ /* dependency on support function, if any */
if (OidIsValid(prosupport)) if (OidIsValid(prosupport))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, prosupport); ObjectAddressSet(referenced, ProcedureRelationId, prosupport);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
record_object_address_dependencies(&myself, addrs, DEPENDENCY_NORMAL);
free_object_addresses(addrs);
/* dependency on parameter default expressions */
if (parameterDefaults)
recordDependencyOnExpr(&myself, (Node *) parameterDefaults,
NIL, DEPENDENCY_NORMAL);
/* dependency on owner */ /* dependency on owner */
if (!is_update) if (!is_update)
recordDependencyOnOwner(ProcedureRelationId, retval, proowner); recordDependencyOnOwner(ProcedureRelationId, retval, proowner);
......
...@@ -43,6 +43,7 @@ RangeCreate(Oid rangeTypeOid, Oid rangeSubType, Oid rangeCollation, ...@@ -43,6 +43,7 @@ RangeCreate(Oid rangeTypeOid, Oid rangeSubType, Oid rangeCollation,
HeapTuple tup; HeapTuple tup;
ObjectAddress myself; ObjectAddress myself;
ObjectAddress referenced; ObjectAddress referenced;
ObjectAddresses *addrs;
pg_range = table_open(RangeRelationId, RowExclusiveLock); pg_range = table_open(RangeRelationId, RowExclusiveLock);
...@@ -61,45 +62,37 @@ RangeCreate(Oid rangeTypeOid, Oid rangeSubType, Oid rangeCollation, ...@@ -61,45 +62,37 @@ RangeCreate(Oid rangeTypeOid, Oid rangeSubType, Oid rangeCollation,
heap_freetuple(tup); heap_freetuple(tup);
/* record type's dependencies on range-related items */ /* record type's dependencies on range-related items */
addrs = new_object_addresses();
myself.classId = TypeRelationId; ObjectAddressSet(myself, TypeRelationId, rangeTypeOid);
myself.objectId = rangeTypeOid;
myself.objectSubId = 0;
referenced.classId = TypeRelationId; ObjectAddressSet(referenced, TypeRelationId, rangeSubType);
referenced.objectId = rangeSubType; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
referenced.classId = OperatorClassRelationId; ObjectAddressSet(referenced, OperatorClassRelationId, rangeSubOpclass);
referenced.objectId = rangeSubOpclass; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
if (OidIsValid(rangeCollation)) if (OidIsValid(rangeCollation))
{ {
referenced.classId = CollationRelationId; ObjectAddressSet(referenced, CollationRelationId, rangeCollation);
referenced.objectId = rangeCollation; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
} }
if (OidIsValid(rangeCanonical)) if (OidIsValid(rangeCanonical))
{ {
referenced.classId = ProcedureRelationId; ObjectAddressSet(referenced, ProcedureRelationId, rangeCanonical);
referenced.objectId = rangeCanonical; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
} }
if (OidIsValid(rangeSubDiff)) if (OidIsValid(rangeSubDiff))
{ {
referenced.classId = ProcedureRelationId; ObjectAddressSet(referenced, ProcedureRelationId, rangeSubDiff);
referenced.objectId = rangeSubDiff; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
} }
record_object_address_dependencies(&myself, addrs, DEPENDENCY_NORMAL);
free_object_addresses(addrs);
table_close(pg_range, RowExclusiveLock); table_close(pg_range, RowExclusiveLock);
} }
......
...@@ -554,6 +554,7 @@ GenerateTypeDependencies(HeapTuple typeTuple, ...@@ -554,6 +554,7 @@ GenerateTypeDependencies(HeapTuple typeTuple,
bool isNull; bool isNull;
ObjectAddress myself, ObjectAddress myself,
referenced; referenced;
ObjectAddresses *addrs_normal;
/* Extract defaultExpr if caller didn't pass it */ /* Extract defaultExpr if caller didn't pass it */
if (defaultExpr == NULL) if (defaultExpr == NULL)
...@@ -587,6 +588,10 @@ GenerateTypeDependencies(HeapTuple typeTuple, ...@@ -587,6 +588,10 @@ GenerateTypeDependencies(HeapTuple typeTuple,
* Skip these for a dependent type, since it will have such dependencies * Skip these for a dependent type, since it will have such dependencies
* indirectly through its depended-on type or relation. * indirectly through its depended-on type or relation.
*/ */
/* placeholder for all normal dependencies */
addrs_normal = new_object_addresses();
if (!isDependentType) if (!isDependentType)
{ {
ObjectAddressSet(referenced, NamespaceRelationId, ObjectAddressSet(referenced, NamespaceRelationId,
...@@ -606,45 +611,70 @@ GenerateTypeDependencies(HeapTuple typeTuple, ...@@ -606,45 +611,70 @@ GenerateTypeDependencies(HeapTuple typeTuple,
if (OidIsValid(typeForm->typinput)) if (OidIsValid(typeForm->typinput))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typinput); ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typinput);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs_normal);
} }
if (OidIsValid(typeForm->typoutput)) if (OidIsValid(typeForm->typoutput))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typoutput); ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typoutput);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs_normal);
} }
if (OidIsValid(typeForm->typreceive)) if (OidIsValid(typeForm->typreceive))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typreceive); ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typreceive);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs_normal);
} }
if (OidIsValid(typeForm->typsend)) if (OidIsValid(typeForm->typsend))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typsend); ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typsend);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs_normal);
} }
if (OidIsValid(typeForm->typmodin)) if (OidIsValid(typeForm->typmodin))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typmodin); ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typmodin);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs_normal);
} }
if (OidIsValid(typeForm->typmodout)) if (OidIsValid(typeForm->typmodout))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typmodout); ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typmodout);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs_normal);
} }
if (OidIsValid(typeForm->typanalyze)) if (OidIsValid(typeForm->typanalyze))
{ {
ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typanalyze); ObjectAddressSet(referenced, ProcedureRelationId, typeForm->typanalyze);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs_normal);
}
/* Normal dependency from a domain to its base type. */
if (OidIsValid(typeForm->typbasetype))
{
ObjectAddressSet(referenced, TypeRelationId, typeForm->typbasetype);
add_exact_object_address(&referenced, addrs_normal);
}
/*
* Normal dependency from a domain to its collation. We know the default
* collation is pinned, so don't bother recording it.
*/
if (OidIsValid(typeForm->typcollation) &&
typeForm->typcollation != DEFAULT_COLLATION_OID)
{
ObjectAddressSet(referenced, CollationRelationId, typeForm->typcollation);
add_exact_object_address(&referenced, addrs_normal);
} }
record_object_address_dependencies(&myself, addrs_normal, DEPENDENCY_NORMAL);
free_object_addresses(addrs_normal);
/* Normal dependency on the default expression. */
if (defaultExpr)
recordDependencyOnExpr(&myself, defaultExpr, NIL, DEPENDENCY_NORMAL);
/* /*
* If the type is a rowtype for a relation, mark it as internally * If the type is a rowtype for a relation, mark it as internally
* dependent on the relation, *unless* it is a stand-alone composite type * dependent on the relation, *unless* it is a stand-alone composite type
...@@ -675,26 +705,6 @@ GenerateTypeDependencies(HeapTuple typeTuple, ...@@ -675,26 +705,6 @@ GenerateTypeDependencies(HeapTuple typeTuple,
recordDependencyOn(&myself, &referenced, recordDependencyOn(&myself, &referenced,
isImplicitArray ? DEPENDENCY_INTERNAL : DEPENDENCY_NORMAL); isImplicitArray ? DEPENDENCY_INTERNAL : DEPENDENCY_NORMAL);
} }
/* Normal dependency from a domain to its base type. */
if (OidIsValid(typeForm->typbasetype))
{
ObjectAddressSet(referenced, TypeRelationId, typeForm->typbasetype);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
}
/* Normal dependency from a domain to its collation. */
/* We know the default collation is pinned, so don't bother recording it */
if (OidIsValid(typeForm->typcollation) &&
typeForm->typcollation != DEFAULT_COLLATION_OID)
{
ObjectAddressSet(referenced, CollationRelationId, typeForm->typcollation);
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
}
/* Normal dependency on the default expression. */
if (defaultExpr)
recordDependencyOnExpr(&myself, defaultExpr, NIL, DEPENDENCY_NORMAL);
} }
/* /*
......
...@@ -1696,6 +1696,7 @@ CreateTransform(CreateTransformStmt *stmt) ...@@ -1696,6 +1696,7 @@ CreateTransform(CreateTransformStmt *stmt)
Relation relation; Relation relation;
ObjectAddress myself, ObjectAddress myself,
referenced; referenced;
ObjectAddresses *addrs;
bool is_replace; bool is_replace;
/* /*
...@@ -1836,39 +1837,34 @@ CreateTransform(CreateTransformStmt *stmt) ...@@ -1836,39 +1837,34 @@ CreateTransform(CreateTransformStmt *stmt)
if (is_replace) if (is_replace)
deleteDependencyRecordsFor(TransformRelationId, transformid, true); deleteDependencyRecordsFor(TransformRelationId, transformid, true);
addrs = new_object_addresses();
/* make dependency entries */ /* make dependency entries */
myself.classId = TransformRelationId; ObjectAddressSet(myself, TransformRelationId, transformid);
myself.objectId = transformid;
myself.objectSubId = 0;
/* dependency on language */ /* dependency on language */
referenced.classId = LanguageRelationId; ObjectAddressSet(referenced, LanguageRelationId, langid);
referenced.objectId = langid; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
/* dependency on type */ /* dependency on type */
referenced.classId = TypeRelationId; ObjectAddressSet(referenced, TypeRelationId, typeid);
referenced.objectId = typeid; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
/* dependencies on functions */ /* dependencies on functions */
if (OidIsValid(fromsqlfuncid)) if (OidIsValid(fromsqlfuncid))
{ {
referenced.classId = ProcedureRelationId; ObjectAddressSet(referenced, ProcedureRelationId, fromsqlfuncid);
referenced.objectId = fromsqlfuncid; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
} }
if (OidIsValid(tosqlfuncid)) if (OidIsValid(tosqlfuncid))
{ {
referenced.classId = ProcedureRelationId; ObjectAddressSet(referenced, ProcedureRelationId, tosqlfuncid);
referenced.objectId = tosqlfuncid; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
} }
record_object_address_dependencies(&myself, addrs, DEPENDENCY_NORMAL);
free_object_addresses(addrs);
/* dependency on extension */ /* dependency on extension */
recordDependencyOnCurrentExtension(&myself, is_replace); recordDependencyOnCurrentExtension(&myself, is_replace);
......
...@@ -57,6 +57,7 @@ CreateProceduralLanguage(CreatePLangStmt *stmt) ...@@ -57,6 +57,7 @@ CreateProceduralLanguage(CreatePLangStmt *stmt)
bool is_update; bool is_update;
ObjectAddress myself, ObjectAddress myself,
referenced; referenced;
ObjectAddresses *addrs;
/* /*
* Check permission * Check permission
...@@ -186,30 +187,29 @@ CreateProceduralLanguage(CreatePLangStmt *stmt) ...@@ -186,30 +187,29 @@ CreateProceduralLanguage(CreatePLangStmt *stmt)
/* dependency on extension */ /* dependency on extension */
recordDependencyOnCurrentExtension(&myself, is_update); recordDependencyOnCurrentExtension(&myself, is_update);
addrs = new_object_addresses();
/* dependency on the PL handler function */ /* dependency on the PL handler function */
referenced.classId = ProcedureRelationId; ObjectAddressSet(referenced, ProcedureRelationId, handlerOid);
referenced.objectId = handlerOid; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
/* dependency on the inline handler function, if any */ /* dependency on the inline handler function, if any */
if (OidIsValid(inlineOid)) if (OidIsValid(inlineOid))
{ {
referenced.classId = ProcedureRelationId; ObjectAddressSet(referenced, ProcedureRelationId, inlineOid);
referenced.objectId = inlineOid; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
} }
/* dependency on the validator function, if any */ /* dependency on the validator function, if any */
if (OidIsValid(valOid)) if (OidIsValid(valOid))
{ {
referenced.classId = ProcedureRelationId; ObjectAddressSet(referenced, ProcedureRelationId, valOid);
referenced.objectId = valOid; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
} }
record_object_address_dependencies(&myself, addrs, DEPENDENCY_NORMAL);
free_object_addresses(addrs);
/* Post creation hook for new procedural language */ /* Post creation hook for new procedural language */
InvokeObjectPostCreateHook(LanguageRelationId, myself.objectId, 0); InvokeObjectPostCreateHook(LanguageRelationId, myself.objectId, 0);
......
...@@ -133,42 +133,41 @@ makeParserDependencies(HeapTuple tuple) ...@@ -133,42 +133,41 @@ makeParserDependencies(HeapTuple tuple)
Form_pg_ts_parser prs = (Form_pg_ts_parser) GETSTRUCT(tuple); Form_pg_ts_parser prs = (Form_pg_ts_parser) GETSTRUCT(tuple);
ObjectAddress myself, ObjectAddress myself,
referenced; referenced;
ObjectAddresses *addrs;
myself.classId = TSParserRelationId; ObjectAddressSet(myself, TSParserRelationId, prs->oid);
myself.objectId = prs->oid;
myself.objectSubId = 0;
/* dependency on namespace */
referenced.classId = NamespaceRelationId;
referenced.objectId = prs->prsnamespace;
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
/* dependency on extension */ /* dependency on extension */
recordDependencyOnCurrentExtension(&myself, false); recordDependencyOnCurrentExtension(&myself, false);
/* dependencies on functions */ addrs = new_object_addresses();
referenced.classId = ProcedureRelationId;
referenced.objectSubId = 0;
referenced.objectId = prs->prsstart; /* dependency on namespace */
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); ObjectAddressSet(referenced, NamespaceRelationId, prs->prsnamespace);
add_exact_object_address(&referenced, addrs);
/* dependencies on functions */
ObjectAddressSet(referenced, ProcedureRelationId, prs->prsstart);
add_exact_object_address(&referenced, addrs);
referenced.objectId = prs->prstoken; referenced.objectId = prs->prstoken;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
referenced.objectId = prs->prsend; referenced.objectId = prs->prsend;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
referenced.objectId = prs->prslextype; referenced.objectId = prs->prslextype;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
if (OidIsValid(prs->prsheadline)) if (OidIsValid(prs->prsheadline))
{ {
referenced.objectId = prs->prsheadline; referenced.objectId = prs->prsheadline;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
record_object_address_dependencies(&myself, addrs, DEPENDENCY_NORMAL);
free_object_addresses(addrs);
return myself; return myself;
} }
...@@ -304,16 +303,9 @@ makeDictionaryDependencies(HeapTuple tuple) ...@@ -304,16 +303,9 @@ makeDictionaryDependencies(HeapTuple tuple)
Form_pg_ts_dict dict = (Form_pg_ts_dict) GETSTRUCT(tuple); Form_pg_ts_dict dict = (Form_pg_ts_dict) GETSTRUCT(tuple);
ObjectAddress myself, ObjectAddress myself,
referenced; referenced;
ObjectAddresses *addrs;
myself.classId = TSDictionaryRelationId; ObjectAddressSet(myself, TSDictionaryRelationId, dict->oid);
myself.objectId = dict->oid;
myself.objectSubId = 0;
/* dependency on namespace */
referenced.classId = NamespaceRelationId;
referenced.objectId = dict->dictnamespace;
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
/* dependency on owner */ /* dependency on owner */
recordDependencyOnOwner(myself.classId, myself.objectId, dict->dictowner); recordDependencyOnOwner(myself.classId, myself.objectId, dict->dictowner);
...@@ -321,11 +313,18 @@ makeDictionaryDependencies(HeapTuple tuple) ...@@ -321,11 +313,18 @@ makeDictionaryDependencies(HeapTuple tuple)
/* dependency on extension */ /* dependency on extension */
recordDependencyOnCurrentExtension(&myself, false); recordDependencyOnCurrentExtension(&myself, false);
addrs = new_object_addresses();
/* dependency on namespace */
ObjectAddressSet(referenced, NamespaceRelationId, dict->dictnamespace);
add_exact_object_address(&referenced, addrs);
/* dependency on template */ /* dependency on template */
referenced.classId = TSTemplateRelationId; ObjectAddressSet(referenced, TSTemplateRelationId, dict->dicttemplate);
referenced.objectId = dict->dicttemplate; add_exact_object_address(&referenced, addrs);
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); record_object_address_dependencies(&myself, addrs, DEPENDENCY_NORMAL);
free_object_addresses(addrs);
return myself; return myself;
} }
...@@ -649,33 +648,32 @@ makeTSTemplateDependencies(HeapTuple tuple) ...@@ -649,33 +648,32 @@ makeTSTemplateDependencies(HeapTuple tuple)
Form_pg_ts_template tmpl = (Form_pg_ts_template) GETSTRUCT(tuple); Form_pg_ts_template tmpl = (Form_pg_ts_template) GETSTRUCT(tuple);
ObjectAddress myself, ObjectAddress myself,
referenced; referenced;
ObjectAddresses *addrs;
myself.classId = TSTemplateRelationId; ObjectAddressSet(myself, TSTemplateRelationId, tmpl->oid);
myself.objectId = tmpl->oid;
myself.objectSubId = 0;
/* dependency on namespace */
referenced.classId = NamespaceRelationId;
referenced.objectId = tmpl->tmplnamespace;
referenced.objectSubId = 0;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
/* dependency on extension */ /* dependency on extension */
recordDependencyOnCurrentExtension(&myself, false); recordDependencyOnCurrentExtension(&myself, false);
/* dependencies on functions */ addrs = new_object_addresses();
referenced.classId = ProcedureRelationId;
referenced.objectSubId = 0;
referenced.objectId = tmpl->tmpllexize; /* dependency on namespace */
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); ObjectAddressSet(referenced, NamespaceRelationId, tmpl->tmplnamespace);
add_exact_object_address(&referenced, addrs);
/* dependencies on functions */
ObjectAddressSet(referenced, ProcedureRelationId, tmpl->tmpllexize);
add_exact_object_address(&referenced, addrs);
if (OidIsValid(tmpl->tmplinit)) if (OidIsValid(tmpl->tmplinit))
{ {
referenced.objectId = tmpl->tmplinit; referenced.objectId = tmpl->tmplinit;
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); add_exact_object_address(&referenced, addrs);
} }
record_object_address_dependencies(&myself, addrs, DEPENDENCY_NORMAL);
free_object_addresses(addrs);
return myself; return myself;
} }
......
...@@ -2069,11 +2069,10 @@ WHERE classid = 'pg_class'::regclass AND ...@@ -2069,11 +2069,10 @@ WHERE classid = 'pg_class'::regclass AND
index concur_reindex_ind3 | column c1 of table concur_reindex_tab | a index concur_reindex_ind3 | column c1 of table concur_reindex_tab | a
index concur_reindex_ind3 | table concur_reindex_tab | a index concur_reindex_ind3 | table concur_reindex_tab | a
index concur_reindex_ind4 | column c1 of table concur_reindex_tab | a index concur_reindex_ind4 | column c1 of table concur_reindex_tab | a
index concur_reindex_ind4 | column c1 of table concur_reindex_tab | a
index concur_reindex_ind4 | column c2 of table concur_reindex_tab | a index concur_reindex_ind4 | column c2 of table concur_reindex_tab | a
materialized view concur_reindex_matview | schema public | n materialized view concur_reindex_matview | schema public | n
table concur_reindex_tab | schema public | n table concur_reindex_tab | schema public | n
(9 rows) (8 rows)
REINDEX INDEX CONCURRENTLY concur_reindex_ind1; REINDEX INDEX CONCURRENTLY concur_reindex_ind1;
REINDEX TABLE CONCURRENTLY concur_reindex_tab; REINDEX TABLE CONCURRENTLY concur_reindex_tab;
...@@ -2097,11 +2096,10 @@ WHERE classid = 'pg_class'::regclass AND ...@@ -2097,11 +2096,10 @@ WHERE classid = 'pg_class'::regclass AND
index concur_reindex_ind3 | column c1 of table concur_reindex_tab | a index concur_reindex_ind3 | column c1 of table concur_reindex_tab | a
index concur_reindex_ind3 | table concur_reindex_tab | a index concur_reindex_ind3 | table concur_reindex_tab | a
index concur_reindex_ind4 | column c1 of table concur_reindex_tab | a index concur_reindex_ind4 | column c1 of table concur_reindex_tab | a
index concur_reindex_ind4 | column c1 of table concur_reindex_tab | a
index concur_reindex_ind4 | column c2 of table concur_reindex_tab | a index concur_reindex_ind4 | column c2 of table concur_reindex_tab | a
materialized view concur_reindex_matview | schema public | n materialized view concur_reindex_matview | schema public | n
table concur_reindex_tab | schema public | n table concur_reindex_tab | schema public | n
(9 rows) (8 rows)
-- Check that comments are preserved -- Check that comments are preserved
CREATE TABLE testcomment (i int); CREATE TABLE testcomment (i int);
......
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