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

ALTER AGGREGATE

ALTER AGGREGATE — 更改一个聚合函数的定义

Synopsis

ALTER AGGREGATE name ( aggregate_signature ) RENAME TO new_name
ALTER AGGREGATE name ( aggregate_signature )
                OWNER TO { new_owner | CURRENT_ROLE | CURRENT_USER | SESSION_USER }
ALTER AGGREGATE name ( aggregate_signature ) SET SCHEMA new_schema

其中 aggregate_signature 是:

* |
[ argmode ] [ argname ] argtype [ , ... ] |
[ [ argmode ] [ argname ] argtype [ , ... ] ] ORDER BY [ argmode ] [ argname ] argtype [ , ... ]

描述

ALTER AGGREGATE更改聚合函数的定义。

要使用ALTER AGGREGATE,你必须拥有该聚合函数。 要更改聚合函数的模式,你还必须在新模式上具有 CREATE权限。要更改拥有者,你必须能够对新的拥有角色执行 SET ROLE,并且该角色必须在该聚合函数所在模式上具有 CREATE权限。(这些限制确保更改拥有者不会做出任何你无法通过删除并重新创建该聚合函数来完成的事情。不过,超级用户无论如何都可以更改任何聚合函数的所有权。)

参数

name #

现有聚合函数的名称(可以用模式限定)。

argmode #

参数的模式:INVARIADIC。 如果省略,默认为IN

argname #

参数的名称。注意,ALTER AGGREGATE 实际上并不关心参数名,因为确定聚合函数的标识只需要参数的数据类型。

argtype #

聚合函数作用于其上的输入数据类型。要引用零参数聚合函数,请在参数说明 列表的位置写上*。要引用有序集聚合函数,请在直接参数 说明和聚合参数说明之间写上ORDER BY

new_name #

聚合函数的新名称。

new_owner #

聚合函数的新拥有者。

new_schema #

聚合函数的新模式。

注解

引用有序集聚合的推荐语法,是像CREATE AGGREGATE 中那样,在直接参数说明和聚合参数说明之间写上ORDER BY。 不过,省略ORDER BY,直接把两部分参数说明合并为一个列 表也同样可行。在这种简写形式中,如果直接参数列表和聚合参数列表中都使用 了VARIADIC "any",则只需写一次VARIADIC "any"

示例

要把用于类型integer的聚合函数 myavg重命名为my_average

ALTER AGGREGATE myavg(integer) RENAME TO my_average;

要把用于类型integer的聚合函数 myavg的拥有者改为joe

ALTER AGGREGATE myavg(integer) OWNER TO joe;

把直接参数类型为float8、聚合参数类型为integer 的有序集聚合mypercentile移动到 模式myschema中:

ALTER AGGREGATE mypercentile(float8 ORDER BY integer) SET SCHEMA myschema;

这也同样可行:

ALTER AGGREGATE mypercentile(float8, integer) SET SCHEMA myschema;

兼容性

在 SQL 标准中没有ALTER AGGREGATE语句。

提交更正

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