[英]Run python or javascript file from postgres function?
我如何从postgres函数运行python或javascript文件?
我有两个结构完全不同的postgres数据库。
但是我需要同步这两个数据库。
我将编写脚本,该脚本将以任何语言(python,java,javascript,node)从本地数据库读取数据并将其写入服务器数据库。
但主要问题是:
我不知道如何从postgres过程或函数调用该脚本。
所以问题是:
我们如何从postgres过程调用或运行任何脚本?
使用plperl
, plpython
或pljava
和使用语言的系统工具集。 即在plpython中使用subprocess
,在java中使用Runtime.getRuntime().exec
等:
例如在plpython
:
CREATE LANGUAGE plpythonu; -- create language if does not exist
CREATE OR REPLACE FUNCTION venue.test_execute()
RETURNS void AS
$BODY$
import subprocess
subprocess.call(['/path/to/script/test.py'])
$BODY$
LANGUAGE plpythonu;
SELECT venue.test_execute();
注意事项
实际上,您可以从Postgres函数启动脚本,但这不是在数据库之间同步数据的首选方法。 您可能会遇到与脚本和数据的绝对路径和相对路径以及文件系统权限有关的问题。 而是使用数据库函数以已知格式导出数据,然后从数据库外部调用同步脚本。 另一个选择是使用dblink模块。
您可以创建一个Perl函数,然后在其中调用脚本来同步数据库。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.