23

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

4

2 回答 2

35

这个问题的一个很好的答案可以在这里找到

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;
于 2012-05-14T21:14:30.880 回答
3

就像有一个postgis.sql启动器安装脚本一样,也有一个uninstall_postgis.sql卸载脚本。

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

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

于 2012-05-14T23:01:41.810 回答