正如Henrik所写,您可以使用dblink连接远程数据库并获取结果.例如:
psql dbtest
CREATE TABLE tblB (id serial, time integer);
INSERT INTO tblB (time) VALUES (5000), (2000);
psql postgres
CREATE TABLE tblA (id serial, time integer);
INSERT INTO tblA
SELECT id, time
FROM dblink('dbname=dbtest', 'SELECT id, time FROM tblB')
AS t(id integer, time integer)
WHERE time > 1000;
TABLE tblA;
id | time
----+------
1 | 5000
2 | 2000
(2 rows)
PostgreSQL有record个伪类型(仅用于函数的参数或结果类型),允许您从另一个(未知)表中查询数据.
编辑:
如果你愿意,你可以把它做成事先准备好的声明,而且它也很有效:
PREPARE migrate_data (integer) AS
INSERT INTO tblA
SELECT id, time
FROM dblink('dbname=dbtest', 'SELECT id, time FROM tblB')
AS t(id integer, time integer)
WHERE time > $1;
EXECUTE migrate_data(1000);
-- DEALLOCATE migrate_data;
编辑(是的,另一个):
我刚刚看到了你的revised question(以复制形式关闭,或者与此非常相似).
如果我的理解是正确的(postgres有tbla,dbtest有tblb,你想要remote insert with local select,而不是上面提到的remote select with local insert):
psql dbtest
SELECT dblink_exec
(
'dbname=postgres',
'INSERT INTO tbla
SELECT id, time
FROM dblink
(
''dbname=dbtest'',
''SELECT id, time FROM tblb''
)
AS t(id integer, time integer)
WHERE time > 1000;'
);
我不喜欢嵌套的dblink,但我不能引用dblink_exec body中的tblB.使用LIMIT指定前20行,但我认为首先需要使用orderby子句对它们进行排序.