从 Postgres 数据库中删除所有函数

Posted

技术标签:

【中文标题】从 Postgres 数据库中删除所有函数【英文标题】:Drop all functions from Postgres database 【发布时间】:2012-05-22 09:31:24 【问题描述】:

我有一个数据库,其中安装了旧版本的 PostGIS。我想轻松删除数据库中的所有函数(它们都来自 PostGIS)。有没有一种简单的方法可以做到这一点?即使只是简单地提取函数名称列表也是可以接受的,因为我可以写一个大的DROP FUNCTION 语句。

【问题讨论】:

【参考方案1】:

正如postgis.sql enabler install script 一样,也有uninstall_postgis.sql 卸载脚本。

psql -d [yourdatabase] -f /path/to/uninstall_postgis.sql

警告:准备好看到您的几何/地理列和数据消失!

【讨论】:

【参考方案2】:

fine answer to this question can be found here:

SELECT 'DROP FUNCTION ' || ns.nspname || '.' || proname 
       || '(' || oidvectortypes(proargtypes) || ');'
FROM pg_proc INNER JOIN pg_namespace ns ON (pg_proc.pronamespace = ns.oid)
WHERE ns.nspname = 'my_messed_up_schema'  order by proname;

【讨论】:

通常,ms.nspname = 'public' 适用。 上述 SQL 将在非小写或非字母数字函数/模式名称上失败。最好使用 quote_ident 或 format('DROP FUNCTION %I.%I(%s);', nspname, proname, oidvectortypes(proargtypes)) 来正确引用 SQL 标识符。 另外值得一提的是,这实际上并没有删除函数,只是生成了随后运行的删除命令。有点问题:-)

以上是关于从 Postgres 数据库中删除所有函数的主要内容,如果未能解决你的问题,请参考以下文章

如何从 Postgres 数据库中删除用户 [重复]

从 postgres 数据库中删除重复条目

为啥我不能使用 node-postgres 从数据库中删除?

在一个命令中删除所有表而不删除 django dbshel​​l 中的 postgres 中的数据库?

从 Greenplum 中的 JSON 中删除 NULL 字段

Postgres:在递归合并函数中删除 jsonb 键