DROP ROUTINE — 移除一个例程
DROP ROUTINE [ IF EXISTS ]name[ ( [ [argmode] [argname]argtype[, ...] ] ) ] [, ...] [ CASCADE | RESTRICT ]
DROP ROUTINE移除一个或多个现有例程的定义。 术语“例程”包括聚合函数、普通函数和过程。关于参数的说明、 更多示例以及进一步细节,请分别参见DROP AGGREGATE、 DROP FUNCTION和DROP PROCEDURE。
DROP ROUTINE所使用的查找规则,从根本上说与 DROP PROCEDURE相同;特别是, DROP ROUTINE与该命令一样:如果参数列表中没有 argmode标记,就会认为它可能采用 SQL 标准的定义, 即将OUT参数也包含在列表中。 (DROP AGGREGATE和DROP FUNCTION不会这样。)
在某些不同种类的例程共享同一名称的情况下,DROP ROUTINE 可能会因为歧义错误而失败,而更具体的命令 (DROP FUNCTION等)则可以工作。 更仔细地指定参数类型列表,同样可以解决这类问题。
这些查找规则也被其他作用于现有例程的命令使用,例如 ALTER ROUTINE和COMMENT ON ROUTINE。
删除参数类型为integer的例程foo:
DROP ROUTINE foo(integer);
不管foo是聚合函数、普通函数还是过程,这条命令都可以工作。
此命令符合 SQL 标准,但有以下PostgreSQL扩展:
标准每条命令只允许删除一个例程。
IF EXISTS选项是扩展。
允许指定参数模式和参数名是扩展,而且在给出模式时查找规则也有所不同。
用户可定义的聚合函数是扩展。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。