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에는 레코드 의사 유형 (함수의 인수 또는 결과 유형에만 해당)이있어 다른 (알 수없는) 테이블에서 데이터를 쿼리 할 수 있습니다.
편집하다:
원하는 경우 준비된 진술로 만들 수 있으며 잘 작동합니다.
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;
편집 (예, 다른) :
방금 수정 된 질문을 봤습니다 (중복으로 마감했거나 이와 매우 유사 함).
내 이해가 정확하다면 (postgres에는 tbla가 있고 dbtest에는 tblb가 있으며 위와 같이 로컬 삽입 으로 원격 선택이 아닌 로컬 선택으로 원격 삽입 을 원합니다 ) :
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가 마음에 들지 않지만 AFAIK dblink_exec 본문 에서 tblB를 참조 할 수 없습니다 . LIMIT를 사용하여 상위 20 개 행을 지정하지만 먼저 ORDER BY 절을 사용하여 정렬해야한다고 생각합니다.