PostgreSQL
 sql >> Base de données >  >> RDS >> PostgreSQL

Postgresql :Fusionner 2 bases de données similaires

Tout d'abord, chargez les tables dans deux schémas distincts dans la même base de données.

CREATE SCHEMA db1;
CREATE TABLE db1.table1 (id INT PRIMARY KEY, value VARCHAR(10));
-- load the contents of Table1 @ Database1 into db1.table1

CREATE SCHEMA db2;
CREATE TABLE db2.table1 (id INT PRIMARY KEY, value VARCHAR(10));
-- load the contents of Table1 @ Database2 into db2.table1

Ensuite, vous pouvez fusionner les deux, en donnant la priorité à db2 sur db1.

SELECT
  DISTINCT ON (id)
  id,
  value
FROM (
  SELECT
    *,
    1 AS db
  FROM
    db1.table1

  UNION

  SELECT
    *,
    2 AS db
  FROM
    db2.table1) AS mix
ORDER BY
  id,
  db DESC;