DROP AGGREGATE — 移除一个聚合函数
DROP AGGREGATE [ IF EXISTS ]name(aggregate_signature) [, ...] [ CASCADE | RESTRICT ] 其中aggregate_signature是: * | [argmode] [argname]argtype[ , ... ] | [ [argmode] [argname]argtype[ , ... ] ] ORDER BY [argmode] [argname]argtype[ , ... ]
DROP AGGREGATE移除一个现有聚合函数。 要执行此命令,当前用户必须是该聚合函数的拥有者。
IF EXISTS如果该聚合函数不存在,则不要抛出错误。这种情况下会发出一个提示。
name现有聚合函数的名称(可以被模式限定)。
argmode参数的模式:IN或VARIADIC。 如果省略,默认值为IN。
argname一个参数的名称。注意,DROP AGGREGATE 实际上不会关注参数名,因为确定聚合函数标识所需的只有参数数据类型。
argtype聚合函数作用于其上的输入数据类型。要引用一个零参数聚合函数, 请在参数说明列表的位置写*。要引用一个有序集聚合函数, 请在直接参数说明和聚合参数说明之间写上ORDER BY。
CASCADE自动删除依赖于该聚合函数的对象(例如使用它的视图),以及进一步依赖于这些对象的所有对象 (参见Section 5.15)。
RESTRICT如果有任何对象依赖于该聚合函数,则拒绝删除它。这是默认值。
关于引用有序集聚合的其他语法,参见ALTER AGGREGATE。
要移除用于类型integer的聚合函数myavg:
DROP AGGREGATE myavg(integer);
要移除假想集聚合函数myrank,它接受任意个排序列组成的列表 以及与之匹配的直接参数列表:
DROP AGGREGATE myrank(VARIADIC "any" ORDER BY VARIADIC "any");
在一条命令中移除多个聚合函数:
DROP AGGREGATE myavg(integer), myavg(bigint);
SQL 标准中没有DROP AGGREGATE语句。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。