ALTER AGGREGATE — 更改一个聚合函数的定义
ALTER AGGREGATEname(aggregate_signature) RENAME TOnew_nameALTER AGGREGATEname(aggregate_signature) OWNER TO {new_owner| CURRENT_ROLE | CURRENT_USER | SESSION_USER } ALTER AGGREGATEname(aggregate_signature) SET SCHEMAnew_schema其中aggregate_signature是: * | [argmode] [argname]argtype[ , ... ] | [ [argmode] [argname]argtype[ , ... ] ] ORDER BY [argmode] [argname]argtype[ , ... ]
ALTER AGGREGATE更改聚合函数的定义。
要使用ALTER AGGREGATE,你必须拥有该聚合函数。 要更改聚合函数的模式,你还必须在新模式上具有 CREATE权限。要更改拥有者,你必须能够对新的拥有角色执行 SET ROLE,并且该角色必须在该聚合函数所在模式上具有 CREATE权限。(这些限制确保更改拥有者不会做出任何你无法通过删除并重新创建该聚合函数来完成的事情。不过,超级用户无论如何都可以更改任何聚合函数的所有权。)
引用有序集聚合的推荐语法,是像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语句。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。