首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >从postgres函数运行python或javascript文件?

从postgres函数运行python或javascript文件?
EN

Stack Overflow用户
提问于 2015-10-24 19:20:43
回答 2查看 1.8K关注 0票数 1

如何从postgres函数运行python或javascript文件?

我有两个postgres数据库,结构完全不同。

但我需要同步这两个数据库。

我会写的脚本,将读取数据从本地数据库和写入到服务器数据库中的任何语言(python,java,javascript,节点)。

但主要的问题是:

我不知道如何从postgres过程或函数调用该脚本。

所以问题是:

我们如何从postgres过程中调用或运行任何脚本?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-10-24 20:29:57

使用plperlplpythonpljava,并使用该语言的系统实用程序。即在plpython中使用subprocess,在java中使用Runtime.getRuntime().exec等等:

例如在plpython

代码语言:javascript
复制
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();

CONSIDERATIONS

实际上,您可以从Postgres函数启动脚本,但这不是在数据库之间同步数据的首选方式。您可能会遇到与脚本和数据的绝对路径和相对路径以及文件系统权限相关的问题。相反,使用数据库函数以已知格式导出数据,并从数据库外部调用同步脚本。另一种选择是使用dblink模块。

票数 4
EN

Stack Overflow用户

发布于 2015-10-24 19:26:31

您可以创建一个Perl Function,并在其中调用您的脚本以同步数据库。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33317582

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档