受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

DROP AGGREGATE

DROP AGGREGATE — 移除一个聚合函数

Synopsis

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

参数的模式:INVARIADIC。 如果省略,默认值为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语句。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。