ALTER ROUTINE — 更改一个例程的定义
ALTER ROUTINEname[ ( [ [argmode] [argname]argtype[, ...] ] ) ]action[ ... ] [ RESTRICT ] ALTER ROUTINEname[ ( [ [argmode] [argname]argtype[, ...] ] ) ] RENAME TOnew_nameALTER ROUTINEname[ ( [ [argmode] [argname]argtype[, ...] ] ) ] OWNER TO {new_owner| CURRENT_ROLE | CURRENT_USER | SESSION_USER } ALTER ROUTINEname[ ( [ [argmode] [argname]argtype[, ...] ] ) ] SET SCHEMAnew_schemaALTER ROUTINEname[ ( [ [argmode] [argname]argtype[, ...] ] ) ] [ NO ] DEPENDS ON EXTENSIONextension_name其中action是以下之一: IMMUTABLE | STABLE | VOLATILE [ NOT ] LEAKPROOF [ EXTERNAL ] SECURITY INVOKER | [ EXTERNAL ] SECURITY DEFINER PARALLEL { UNSAFE | RESTRICTED | SAFE } COSTexecution_costROWSresult_rowsSETconfiguration_parameter{ TO | = } {value| DEFAULT } SETconfiguration_parameterFROM CURRENT RESETconfiguration_parameterRESET ALL
ALTER ROUTINE更改一个例程的定义。 术语“例程”包括聚合函数、普通函数和过程。 参数说明、更多示例以及进一步细节, 请分别参见ALTER AGGREGATE、 ALTER FUNCTION和ALTER PROCEDURE。
将针对integer类型的例程foo重命名为foobar:
ALTER ROUTINE foo(integer) RENAME TO foobar;
不管foo是聚合、函数还是过程,这条命令都可以工作。
该语句与 SQL 标准中的ALTER ROUTINE语句部分兼容。 更多细节请参见ALTER FUNCTION和ALTER PROCEDURE。 允许例程名引用聚合函数是PostgreSQL的扩展。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。