【发布时间】:2012-05-22 09:31:24
【问题描述】:
我有一个数据库,其中安装了旧版本的 PostGIS。我想轻松删除数据库中的所有函数(它们都来自 PostGIS)。有没有一种简单的方法可以做到这一点?即使只是简单地提取函数名称列表也是可以接受的,因为我可以写一个大的DROP FUNCTION 语句。
【问题讨论】:
标签: postgresql postgis
我有一个数据库,其中安装了旧版本的 PostGIS。我想轻松删除数据库中的所有函数(它们都来自 PostGIS)。有没有一种简单的方法可以做到这一点?即使只是简单地提取函数名称列表也是可以接受的,因为我可以写一个大的DROP FUNCTION 语句。
【问题讨论】:
标签: postgresql postgis
正如postgis.sql enabler install script 一样,也有uninstall_postgis.sql 卸载脚本。
psql -d [yourdatabase] -f /path/to/uninstall_postgis.sql
警告:准备好看到您的几何/地理列和数据消失!
【讨论】:
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' 适用。