当前位置: 代码迷 >> python >> 从postgres函数运行python或javascript文件?
  详细解决方案

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

热度:53   发布时间:2023-06-14 08:43:10.0

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

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

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

我将编写脚本,该脚本将以任何语言(python,java,javascript,node)从本地数据库读取数据并将其写入服务器数据库。

但主要问题是:

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

所以问题是:

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

使用plperlplpythonpljava和使用语言的系统工具集。 即在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函数启动脚本,但这不是在数据库之间同步数据的首选方法。 您可能会遇到与脚本和数据的绝对路径和相对路径以及文件系统权限有关的问题。 而是使用数据库函数以已知格式导出数据,然后从数据库外部调用同步脚本。 另一个选择是使用模块。

您可以创建一个然后在其中调用脚本来同步数据库。

  相关解决方案