PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

Controlla se i record esistono in una tabella Postgres

Questo dovrebbe funzionare bene:

CREATE TEMP TABLE tmp AS SELECT * FROM tbl LIMIT 0 -- copy layout, but no data

COPY tmp FROM '/absolute/path/to/file' FORMAT csv;

INSERT INTO tbl
SELECT tmp.*
FROM   tmp
LEFT   JOIN tbl USING (tbl_id)
WHERE  tbl.tbl_id IS NULL;

DROP TABLE tmp; -- else dropped at end of session automatically

Strettamente correlato a questa risposta .