85#include "utils/fmgroids.h"
102#define DEPFLAG_ORIGINAL 0x0001
103#define DEPFLAG_NORMAL 0x0002
104#define DEPFLAG_AUTO 0x0004
105#define DEPFLAG_INTERNAL 0x0008
106#define DEPFLAG_PARTITION 0x0010
107#define DEPFLAG_EXTENSION 0x0020
108#define DEPFLAG_REVERSE 0x0040
109#define DEPFLAG_IS_PART 0x0080
110#define DEPFLAG_SUBOBJECT 0x0100
200 bool original =
false;
449 int numDependentObjects;
450 int maxDependentObjects;
497 (
errcode(ERRCODE_DEPENDENT_OBJECTS_STILL_EXIST),
498 errmsg(
"cannot drop %s because it is required by the database system",
512 Anum_pg_depend_classid,
516 Anum_pg_depend_objid,
523 Anum_pg_depend_objsubid,
538 memset(&owningObject, 0,
sizeof(owningObject));
539 memset(&partitionObject, 0,
sizeof(partitionObject));
545 otherObject.
classId = foundDep->refclassid;
546 otherObject.
objectId = foundDep->refobjid;
561 switch (foundDep->deptype)
589 otherObject.
classId == ExtensionRelationId &&
617 if (pendingObjects &&
638 owningObject = otherObject;
723 elog(
ERROR,
"deletion of owning object %s failed to delete %s",
744 partitionObject = otherObject;
754 partitionObject = otherObject;
765 elog(
ERROR,
"unrecognized dependency type '%c' for %s",
789 (
errcode(ERRCODE_DEPENDENT_OBJECTS_STILL_EXIST),
790 errmsg(
"cannot drop %s because %s requires it",
792 errhint(
"You can drop %s instead.", otherObjDesc)));
803 maxDependentObjects = 128;
806 numDependentObjects = 0;
809 Anum_pg_depend_refclassid,
813 Anum_pg_depend_refobjid,
819 Anum_pg_depend_refobjsubid,
835 otherObject.
classId = foundDep->classid;
836 otherObject.
objectId = foundDep->objid;
873 switch (foundDep->deptype)
893 elog(
ERROR,
"unrecognized dependency type '%c' for %s",
900 if (numDependentObjects >= maxDependentObjects)
903 maxDependentObjects *= 2;
909 dependentObjects[numDependentObjects].
obj = otherObject;
910 dependentObjects[numDependentObjects].
subflags = subflags;
911 numDependentObjects++;
921 if (numDependentObjects > 1)
922 qsort(dependentObjects, numDependentObjects,
931 mystack.
flags = objflags;
932 mystack.
next = stack;
934 for (
int i = 0;
i < numDependentObjects;
i++)
947 pfree(dependentObjects);
990 int numReportedClient = 0;
991 int numNotReportedClient = 0;
1016 (
errcode(ERRCODE_DEPENDENT_OBJECTS_STILL_EXIST),
1017 errmsg(
"cannot drop %s because %s requires it",
1019 errhint(
"You can drop %s instead.", otherObjDesc)));
1037#define MAX_REPORTED_DEPS 100
1046 for (
i = targetObjects->
numrefs - 1;
i >= 0;
i--)
1063 if (objDesc == NULL)
1096 if (clientdetail.
len != 0)
1099 objDesc, otherDesc);
1100 numReportedClient++;
1103 numNotReportedClient++;
1105 if (logdetail.
len != 0)
1108 objDesc, otherDesc);
1112 numNotReportedClient++;
1120 if (clientdetail.
len != 0)
1124 numReportedClient++;
1127 numNotReportedClient++;
1129 if (logdetail.
len != 0)
1138 if (numNotReportedClient > 0)
1140 "(see server log for list)",
1141 "\nand %d other objects "
1142 "(see server log for list)",
1143 numNotReportedClient),
1144 numNotReportedClient);
1150 (
errcode(ERRCODE_DEPENDENT_OBJECTS_STILL_EXIST),
1151 errmsg(
"cannot drop %s because other objects depend on it",
1155 errhint(
"Use DROP ... CASCADE to drop the dependent objects too.")));
1158 (
errcode(ERRCODE_DEPENDENT_OBJECTS_STILL_EXIST),
1159 errmsg(
"cannot drop desired object(s) because other objects depend on them"),
1162 errhint(
"Use DROP ... CASCADE to drop the dependent objects too.")));
1164 else if (numReportedClient > 1)
1168 "drop cascades to %d other objects",
1169 numReportedClient + numNotReportedClient,
1170 numReportedClient + numNotReportedClient),
1174 else if (numReportedClient == 1)
1207 elog(
ERROR,
"cache lookup failed for %s %u",
1230 elog(
ERROR,
"could not find tuple for %s %u",
1291 Anum_pg_depend_classid,
1295 Anum_pg_depend_objid,
1301 Anum_pg_depend_objsubid,
1357 case RelationRelationId:
1361 if (relKind == RELKIND_INDEX ||
1362 relKind == RELKIND_PARTITIONED_INDEX)
1383 if (relKind == RELKIND_SEQUENCE)
1388 case ProcedureRelationId:
1392 case TypeRelationId:
1396 case ConstraintRelationId:
1400 case AttrDefaultRelationId:
1404 case LargeObjectRelationId:
1408 case OperatorRelationId:
1412 case RewriteRelationId:
1416 case TriggerRelationId:
1420 case StatisticExtRelationId:
1424 case TSConfigRelationId:
1428 case ExtensionRelationId:
1432 case PolicyRelationId:
1436 case PublicationNamespaceRelationId:
1440 case PublicationRelRelationId:
1444 case PublicationRelationId:
1448 case CastRelationId:
1449 case CollationRelationId:
1450 case ConversionRelationId:
1451 case LanguageRelationId:
1452 case OperatorClassRelationId:
1453 case OperatorFamilyRelationId:
1454 case AccessMethodRelationId:
1455 case AccessMethodOperatorRelationId:
1456 case AccessMethodProcedureRelationId:
1457 case NamespaceRelationId:
1458 case TSParserRelationId:
1459 case TSDictionaryRelationId:
1460 case TSTemplateRelationId:
1461 case ForeignDataWrapperRelationId:
1462 case ForeignServerRelationId:
1463 case UserMappingRelationId:
1464 case DefaultAclRelationId:
1465 case EventTriggerRelationId:
1466 case TransformRelationId:
1467 case AuthMemRelationId:
1474 case AuthIdRelationId:
1475 case DatabaseRelationId:
1476 case TableSpaceRelationId:
1477 case SubscriptionRelationId:
1478 case ParameterAclRelationId:
1479 elog(
ERROR,
"global objects cannot be deleted by doDeletion");
1602 context.
addrs = addrs;
1641 rte.type = T_RangeTblEntry;
1644 rte.relkind = RELKIND_RELATION;
1656 if ((behavior != self_behavior || reverse_self) &&
1668 for (oldref = 0; oldref < context.
addrs->
numrefs; oldref++)
1672 if (thisobj->
classId == RelationRelationId &&
1698 for (selfref = 0; selfref < self_addrs->
numrefs; selfref++)
1802 con->constcollid != DEFAULT_COLLATION_OID)
1812 if (!con->constisnull)
1817 case REGPROCEDUREOID:
1825 case REGOPERATOROID:
1846 case REGCOLLATIONOID:
1860 case REGDICTIONARYOID:
1868 case REGNAMESPACEOID:
1882 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
1883 errmsg(
"constant of the type %s cannot be used here",
1891 case REGDATABASEOID:
1893 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
1894 errmsg(
"constant of the type %s cannot be used here",
1980 if (sbsref->refrestype != sbsref->refcontainertype &&
1981 sbsref->refrestype != sbsref->refelemtype)
1989 elog(
ERROR,
"already-planned subqueries not supported");
2014 fselect->resultcollid != DEFAULT_COLLATION_OID)
2028 foreach(l, fstore->fieldnums)
2045 relab->resultcollid != DEFAULT_COLLATION_OID)
2058 iocoerce->resultcollid != DEFAULT_COLLATION_OID)
2071 acoerce->resultcollid != DEFAULT_COLLATION_OID)
2103 foreach(l, rcexpr->opnos)
2108 foreach(l, rcexpr->opfamilies)
2160 wc->inRangeColl != DEFAULT_COLLATION_OID)
2203 foreach(lc, query->
rtable)
2229 for (
int i = 0;
i < rte->joinmergedcols;
i++)
2248 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
2249 errmsg(
"transition table \"%s\" cannot be referenced in a persistent object",
2250 rte->eref->aliasname)));
2270 if (query->resultRelation <= 0 ||
2272 elog(
ERROR,
"invalid resultRelation %d",
2273 query->resultRelation);
2292 foreach(lc, query->constraintDeps)
2326 foreach(ct, rtfunc->funccoltypes)
2331 foreach(ct, rtfunc->funccolcollations)
2348 foreach(ct, tf->coltypes)
2353 foreach(ct, tf->colcollations)
2396 if (
attnum > atts_done &&
2397 attnum <= atts_done + rtfunc->funccolcount)
2402 if (rtfunc->funccolnames !=
NIL)
2406 if (tupdesc && tupdesc->
tdtypeid != RECORDOID)
2424 atts_done += rtfunc->funccolcount;
2433 (
errcode(ERRCODE_UNDEFINED_COLUMN),
2434 errmsg(
"column %d of relation \"%s\" does not exist",
2435 attnum, rte->eref->aliasname)));
2475 *foundobj = *thisobj;
2507 priorobj = addrs->
refs;
2509 for (oldref = 1; oldref < addrs->
numrefs; oldref++)
2535 *priorobj = *thisobj;
2686 *itemextra = *extra;
2726 bool result =
false;
2799 bool result =
false;
2802 for (stackptr = stack; stackptr; stackptr = stackptr->
next)
2899 Anum_pg_init_privs_objoid,
2903 Anum_pg_init_privs_classoid,
2909 Anum_pg_init_privs_objsubid,
#define InvalidAttrNumber
#define ngettext(s, p, n)
#define OidIsValid(objectId)
bool IsPinnedObject(Oid classId, Oid objectId)
void DeleteSequenceTuple(Oid relid)
static bool object_address_present_add_flags(const ObjectAddress *object, int flags, ObjectAddresses *addrs)
#define DEPFLAG_PARTITION
void performMultipleDeletions(const ObjectAddresses *objects, DropBehavior behavior, int flags)
struct ObjectAddressStack ObjectAddressStack
static void add_exact_object_address_extra(const ObjectAddress *object, const ObjectAddressExtra *extra, ObjectAddresses *addrs)
void record_object_address_dependencies(const ObjectAddress *depender, ObjectAddresses *referenced, DependencyType behavior)
static void DropObjectById(const ObjectAddress *object)
static int object_address_comparator(const void *a, const void *b)
void sort_object_addresses(ObjectAddresses *addrs)
static void doDeletion(const ObjectAddress *object, int flags)
static bool stack_address_present_add_flags(const ObjectAddress *object, int flags, ObjectAddressStack *stack)
static void add_object_address(Oid classId, Oid objectId, int32 subId, ObjectAddresses *addrs)
static bool find_expr_references_walker(Node *node, find_expr_references_context *context)
static void eliminate_duplicate_dependencies(ObjectAddresses *addrs)
void AcquireDeletionLock(const ObjectAddress *object, int flags)
void performDeletion(const ObjectAddress *object, DropBehavior behavior, int flags)
static void deleteOneObject(const ObjectAddress *object, Relation *depRel, int32 flags)
static void DeleteInitPrivs(const ObjectAddress *object)
#define MAX_REPORTED_DEPS
static void process_function_rte_ref(RangeTblEntry *rte, AttrNumber attnum, find_expr_references_context *context)
static void reportDependentObjects(const ObjectAddresses *targetObjects, DropBehavior behavior, int flags, const ObjectAddress *origObject)
void ReleaseDeletionLock(const ObjectAddress *object)
void recordDependencyOnSingleRelExpr(const ObjectAddress *depender, Node *expr, Oid relId, DependencyType behavior, DependencyType self_behavior, bool reverse_self)
void recordDependencyOnExpr(const ObjectAddress *depender, Node *expr, List *rtable, DependencyType behavior)
static void findDependentObjects(const ObjectAddress *object, int objflags, int flags, ObjectAddressStack *stack, ObjectAddresses *targetObjects, const ObjectAddresses *pendingObjects, Relation *depRel)
void collectDependenciesOfExpr(ObjectAddresses *addrs, Node *expr, List *rtable)
bool object_address_present(const ObjectAddress *object, const ObjectAddresses *addrs)
bool find_temp_object(const ObjectAddresses *addrs, bool local_temp_okay, ObjectAddress *foundobj)
void add_exact_object_address(const ObjectAddress *object, ObjectAddresses *addrs)
ObjectAddresses * new_object_addresses(void)
#define DEPFLAG_SUBOBJECT
#define DEPFLAG_EXTENSION
static void deleteObjectsInList(ObjectAddresses *targetObjects, Relation *depRel, int flags)
void free_object_addresses(ObjectAddresses *addrs)
#define PERFORM_DELETION_CONCURRENTLY
#define PERFORM_DELETION_SKIP_EXTENSIONS
@ DEPENDENCY_AUTO_EXTENSION
@ DEPENDENCY_PARTITION_PRI
@ DEPENDENCY_PARTITION_SEC
#define PERFORM_DELETION_CONCURRENT_LOCK
#define PERFORM_DELETION_QUIETLY
#define PERFORM_DELETION_SKIP_ORIGINAL
#define PERFORM_DELETION_INTERNAL
int errmsg_plural(const char *fmt_singular, const char *fmt_plural, unsigned long n,...)
int errmsg_internal(const char *fmt,...)
int errdetail_internal(const char *fmt,...)
int errhint(const char *fmt,...)
bool message_level_is_interesting(int elevel)
int errcode(int sqlerrcode)
int errmsg(const char *fmt,...)
int errdetail_log(const char *fmt,...)
#define ereport(elevel,...)
void EventTriggerSQLDropAddObject(const ObjectAddress *object, bool original, bool normal)
bool trackDroppedObjectsNeeded(void)
bool EventTriggerSupportsObject(const ObjectAddress *object)
Oid CurrentExtensionObject
void RemoveExtensionById(Oid extId)
TupleDesc get_expr_result_tupdesc(Node *expr, bool noError)
void RemoveFunctionById(Oid funcOid)
void systable_endscan(SysScanDesc sysscan)
bool systable_recheck_tuple(SysScanDesc sysscan, HeapTuple tup)
HeapTuple systable_getnext(SysScanDesc sysscan)
SysScanDesc systable_beginscan(Relation heapRelation, Oid indexId, bool indexOK, Snapshot snapshot, int nkeys, ScanKey key)
Assert(PointerIsAligned(start, uint64))
void RemoveAttributeById(Oid relid, AttrNumber attnum)
void heap_drop_with_catalog(Oid relid)
#define HeapTupleIsValid(tuple)
static void * GETSTRUCT(const HeapTupleData *tuple)
void index_drop(Oid indexId, bool concurrent, bool concurrent_lock_mode)
void CatalogTupleDelete(Relation heapRel, const ItemPointerData *tid)
List * list_delete_first(List *list)
List * lcons(void *datum, List *list)
void LockSharedObject(Oid classid, Oid objid, uint16 objsubid, LOCKMODE lockmode)
void UnlockRelationOid(Oid relid, LOCKMODE lockmode)
void LockDatabaseObject(Oid classid, Oid objid, uint16 objsubid, LOCKMODE lockmode)
void LockRelationOid(Oid relid, LOCKMODE lockmode)
void UnlockDatabaseObject(Oid classid, Oid objid, uint16 objsubid, LOCKMODE lockmode)
#define AccessExclusiveLock
#define ShareUpdateExclusiveLock
char get_rel_relkind(Oid relid)
Oid get_typ_typrelid(Oid typid)
Oid getBaseType(Oid typid)
void * repalloc(void *pointer, Size size)
void pfree(void *pointer)
bool isTempNamespace(Oid namespaceId)
bool isAnyTempNamespace(Oid namespaceId)
Oid exprType(const Node *expr)
#define query_tree_walker(q, w, c, f)
#define QTW_EXAMINE_SORTGROUP
#define expression_tree_walker(n, w, c)
#define QTW_IGNORE_JOINALIASES
#define IsA(nodeptr, _type_)
#define InvokeObjectDropHookArg(classId, objectId, subId, dropflags)
AttrNumber get_object_attnum_oid(Oid class_id)
const char * get_object_class_descr(Oid class_id)
char * getObjectDescription(const ObjectAddress *object, bool missing_ok)
int get_object_catcache_oid(Oid class_id)
Oid get_object_oid_index(Oid class_id)
Oid get_object_namespace(const ObjectAddress *address)
void RemoveOperatorById(Oid operOid)
#define rt_fetch(rangetable_index, rangetable)
void RemoveAttrDefaultById(Oid attrdefId)
void RemoveConstraintById(Oid conId)
void recordMultipleDependencies(const ObjectAddress *depender, const ObjectAddress *referenced, int nreferenced, DependencyType behavior)
void recordDependencyOn(const ObjectAddress *depender, const ObjectAddress *referenced, DependencyType behavior)
FormData_pg_depend * Form_pg_depend
void LargeObjectDrop(Oid loid)
static int list_length(const List *l)
static void * list_nth(const List *list, int n)
void deleteSharedDependencyRecordsFor(Oid classId, Oid objectId, int32 objectSubId)
void RemovePolicyById(Oid policy_id)
#define qsort(a, b, c, d)
static Oid DatumGetObjectId(Datum X)
static Datum ObjectIdGetDatum(Oid X)
static Datum Int32GetDatum(int32 X)
void RemovePublicationSchemaById(Oid psoid)
void RemovePublicationById(Oid pubid)
void RemovePublicationRelById(Oid proid)
void RemoveRewriteRuleById(Oid ruleOid)
void ScanKeyInit(ScanKey entry, AttrNumber attributeNumber, StrategyNumber strategy, RegProcedure procedure, Datum argument)
void DeleteSecurityLabel(const ObjectAddress *object)
void check_stack_depth(void)
void RemoveStatisticsById(Oid statsOid)
#define BTEqualStrategyNumber
void appendStringInfo(StringInfo str, const char *fmt,...)
void appendStringInfoChar(StringInfo str, char ch)
void initStringInfo(StringInfo str)
const ObjectAddress * object
struct ObjectAddressStack * next
ObjectAddressExtra * extras
void ReleaseSysCache(HeapTuple tuple)
HeapTuple SearchSysCache1(int cacheId, Datum key1)
#define SearchSysCacheExists1(cacheId, key1)
void table_close(Relation relation, LOCKMODE lockmode)
Relation table_open(Oid relationId, LOCKMODE lockmode)
void RemoveTriggerById(Oid trigOid)
void RemoveTSConfigurationById(Oid cfgId)
void RemoveTypeById(Oid typeOid)
void CommandCounterIncrement(void)