[英]How to take backup of functions only in Postgres
我想备份我的 postgres 数据库中的所有函数。如何只备份 Postgres 中的函数?
使用pg_getfunctiondef
; 查看系统信息功能。 pg_getfunctiondef
是在 PostgreSQL 8.4 中添加的。
SELECT pg_get_functiondef('proc_name'::regproc);
要转储模式中的所有函数,您可以查询pg_catalog
中的系统表; 说如果你想要public
的一切:
SELECT pg_get_functiondef(f.oid)
FROM pg_catalog.pg_proc f
INNER JOIN pg_catalog.pg_namespace n ON (f.pronamespace = n.oid)
WHERE n.nspname = 'public';
如果您想要的话,将上面的内容更改为“从除以pg_
的所有模式之外的所有模式”是微不足道的。
在psql
中,您可以将其转储到文件中:
psql -At dbname > /path/to/output/file.sql <<"__END__"
... the above SQL ...
__END__
要在另一个数据库中运行输出,请使用类似:
psql -1 -v ON_ERROR_STOP -f /path/to/output/file.sql target_db_name
但是,如果您像这样在 DB 之间复制函数,请考虑将函数定义的权威副本作为 SQL 脚本存储在修订控制系统(如 svn 或 git)中,最好打包为 PostgreSQL 扩展。 请参阅打包扩展。
你不能告诉pg_dump
只转储函数。 但是,您可以在没有数据的情况下进行转储( -s
或--schema-only
)并在恢复时对其进行过滤。 注意--format=c
(也是-Fc
)部分:这将生成一个适合pg_restore
的文件。
首先采取转储:
pg_dump -U username --format=c --schema-only -f dump_test your_database
然后创建函数列表:
pg_restore --list dump_test | grep FUNCTION > function_list
最后恢复它们( -L
或--use-list
指定上面创建的列表文件):
pg_restore -U username -d your_other_database -L function_list dump_test
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.