42 Oid operatorNamespace,
53 Oid operatorNamespace,
58 Oid otherLeftTypeId,
Oid otherRightTypeId,
59 const char *operatorName,
Oid operatorNamespace,
60 Oid leftTypeId,
Oid rightTypeId,
84 if (strspn(
name,
"~!@#^&|`?+-*/%<>=") !=
len)
88 if (strstr(
name,
"/*") || strstr(
name,
"--"))
104 for (ic =
len - 2; ic >= 0; ic--)
106 if (strchr(
"~!@#^&|`?%",
name[ic]))
114 if (strcmp(
name,
"!=") == 0)
131 Oid operatorNamespace,
137 Oid operatorObjectId;
148 operatorObjectId = oprform->oid;
158 return operatorObjectId;
175 Oid operatorObjectId;
179 leftObjectId, rightObjectId,
190 return operatorObjectId;
200 Oid operatorNamespace,
205 Oid operatorObjectId;
209 bool nulls[Natts_pg_operator];
218 (
errcode(ERRCODE_INVALID_NAME),
219 errmsg(
"\"%s\" is not a valid operator name",
226 tupDesc = pg_operator_desc->
rd_att;
231 for (
i = 0;
i < Natts_pg_operator; ++
i)
242 Anum_pg_operator_oid);
288 return operatorObjectId;
328 Oid operatorNamespace,
332 List *commutatorName,
342 bool nulls[Natts_pg_operator];
343 bool replaces[Natts_pg_operator];
345 Oid operatorObjectId;
346 bool operatorAlreadyDefined;
350 bool selfCommutator =
false;
360 (
errcode(ERRCODE_INVALID_NAME),
361 errmsg(
"\"%s\" is not a valid operator name",
369 (
errcode(ERRCODE_INVALID_FUNCTION_DEFINITION),
370 errmsg(
"only binary operators can have commutators")));
373 (
errcode(ERRCODE_INVALID_FUNCTION_DEFINITION),
374 errmsg(
"only binary operators can have join selectivity")));
377 (
errcode(ERRCODE_INVALID_FUNCTION_DEFINITION),
378 errmsg(
"only binary operators can merge join")));
381 (
errcode(ERRCODE_INVALID_FUNCTION_DEFINITION),
382 errmsg(
"only binary operators can hash")));
387 if (operResultType != BOOLOID)
392 (
errcode(ERRCODE_INVALID_FUNCTION_DEFINITION),
393 errmsg(
"only boolean operators can have negators")));
396 (
errcode(ERRCODE_INVALID_FUNCTION_DEFINITION),
397 errmsg(
"only boolean operators can have restriction selectivity")));
400 (
errcode(ERRCODE_INVALID_FUNCTION_DEFINITION),
401 errmsg(
"only boolean operators can have join selectivity")));
404 (
errcode(ERRCODE_INVALID_FUNCTION_DEFINITION),
405 errmsg(
"only boolean operators can merge join")));
408 (
errcode(ERRCODE_INVALID_FUNCTION_DEFINITION),
409 errmsg(
"only boolean operators can hash")));
416 &operatorAlreadyDefined);
418 if (operatorAlreadyDefined)
420 (
errcode(ERRCODE_DUPLICATE_FUNCTION),
421 errmsg(
"operator %s already exists",
443 rightTypeId, leftTypeId,
444 operatorName, operatorNamespace,
445 leftTypeId, rightTypeId,
459 selfCommutator =
true;
468 leftTypeId, rightTypeId,
469 operatorName, operatorNamespace,
470 leftTypeId, rightTypeId,
486 for (
i = 0;
i < Natts_pg_operator; ++
i)
514 if (operatorObjectId)
521 elog(
ERROR,
"cache lookup failed for operator %u",
524 replaces[Anum_pg_operator_oid - 1] =
false;
539 Anum_pg_operator_oid);
568 commutatorId = operatorObjectId;
571 OperatorUpd(operatorObjectId, commutatorId, negatorId,
false);
586 const char *operatorName,
Oid operatorNamespace,
587 Oid leftTypeId,
Oid rightTypeId,
bool isCommutator)
609 if (strcmp(otherName, operatorName) == 0 &&
610 otherNamespace == operatorNamespace &&
611 otherLeftTypeId == leftTypeId &&
612 otherRightTypeId == rightTypeId)
620 (
errcode(ERRCODE_INVALID_FUNCTION_DEFINITION),
621 errmsg(
"operator cannot be its own negator or sort operator")));
681 bool update_commutator =
false;
688 if (isDelete && t->oprcom == baseId)
691 update_commutator =
true;
696 update_commutator =
true;
700 if (update_commutator)
726 bool update_negator =
false;
733 if (isDelete && t->oprnegate == baseId)
736 update_negator =
true;
738 else if (!isDelete && !
OidIsValid(t->oprnegate))
740 t->oprnegate = baseId;
741 update_negator =
true;
778 bool makeExtensionDep,
865 if (makeExtensionDep)
void aclcheck_error(AclResult aclerr, ObjectType objtype, const char *objectname)
AclResult object_aclcheck(Oid classid, Oid objectid, Oid roleid, AclMode mode)
bool object_ownercheck(Oid classid, Oid objectid, Oid roleid)
static Datum values[MAXATTR]
#define RegProcedureIsValid(p)
#define OidIsValid(objectId)
Oid GetNewOidWithIndex(Relation relation, Oid indexId, AttrNumber oidcolumn)
elog(ERROR, "%s: %s", p2, msg)
void record_object_address_dependencies(const ObjectAddress *depender, ObjectAddresses *referenced, DependencyType behavior)
ObjectAddresses * new_object_addresses(void)
void add_exact_object_address(const ObjectAddress *object, ObjectAddresses *addrs)
void free_object_addresses(ObjectAddresses *addrs)
int errcode(int sqlerrcode)
int errmsg(const char *fmt,...)
#define ereport(elevel,...)
HeapTuple heap_form_tuple(TupleDesc tupleDescriptor, Datum *values, bool *isnull)
HeapTuple heap_modify_tuple(HeapTuple tuple, TupleDesc tupleDesc, Datum *replValues, bool *replIsnull, bool *doReplace)
void heap_freetuple(HeapTuple htup)
#define HeapTupleIsValid(tuple)
void CatalogTupleUpdate(Relation heapRel, ItemPointer otid, HeapTuple tup)
void CatalogTupleInsert(Relation heapRel, HeapTuple tup)
char * get_namespace_name(Oid nspid)
RegProcedure get_opcode(Oid opno)
Oid get_func_rettype(Oid funcid)
void namestrcpy(Name name, const char *str)
Oid QualifiedNameGetCreationNamespace(const List *names, char **objname_p)
char * NameListToString(const List *names)
#define InvokeObjectPostCreateHook(classId, objectId, subId)
#define ObjectAddressSet(addr, class_id, object_id)
Oid LookupOperName(ParseState *pstate, List *opername, Oid oprleft, Oid oprright, bool noError, int location)
Operator oper(ParseState *pstate, List *opname, Oid ltypeId, Oid rtypeId, bool noError, int location)
long deleteDependencyRecordsFor(Oid classId, Oid objectId, bool skipExtensionDeps)
void recordDependencyOnCurrentExtension(const ObjectAddress *object, bool isReplace)
static Oid OperatorLookup(List *operatorName, Oid leftObjectId, Oid rightObjectId, bool *defined)
static Oid OperatorShellMake(const char *operatorName, Oid operatorNamespace, Oid leftTypeId, Oid rightTypeId)
static Oid OperatorGet(const char *operatorName, Oid operatorNamespace, Oid leftObjectId, Oid rightObjectId, bool *defined)
static bool validOperatorName(const char *name)
ObjectAddress OperatorCreate(const char *operatorName, Oid operatorNamespace, Oid leftTypeId, Oid rightTypeId, Oid procedureId, List *commutatorName, List *negatorName, Oid restrictionId, Oid joinId, bool canMerge, bool canHash)
static Oid get_other_operator(List *otherOp, Oid otherLeftTypeId, Oid otherRightTypeId, const char *operatorName, Oid operatorNamespace, Oid leftTypeId, Oid rightTypeId, bool isCommutator)
ObjectAddress makeOperatorDependencies(HeapTuple tuple, bool makeExtensionDep, bool isUpdate)
void OperatorUpd(Oid baseId, Oid commId, Oid negId, bool isDelete)
FormData_pg_operator * Form_pg_operator
void deleteSharedDependencyRecordsFor(Oid classId, Oid objectId, int32 objectSubId)
void recordDependencyOnOwner(Oid classId, Oid objectId, Oid owner)
static Datum PointerGetDatum(const void *X)
static Datum BoolGetDatum(bool X)
static Datum ObjectIdGetDatum(Oid X)
static Datum NameGetDatum(const NameData *X)
static Datum CharGetDatum(char X)
#define RelationGetDescr(relation)
void ReleaseSysCache(HeapTuple tuple)
HeapTuple SearchSysCache4(int cacheId, Datum key1, Datum key2, Datum key3, Datum key4)
#define SearchSysCacheCopy1(cacheId, key1)
void table_close(Relation relation, LOCKMODE lockmode)
Relation table_open(Oid relationId, LOCKMODE lockmode)
void CommandCounterIncrement(void)