Re: How to insert a bulk of data with unique-violations very fast - Mailing list pgsql-performance

From Pierre C
Subject Re: How to insert a bulk of data with unique-violations very fast
Date
Msg-id op.vdxvs5l9eorkce@apollo13
Whole thread Raw
In response to Re: How to insert a bulk of data with unique-violations very fast  (Torsten Zühlsdorff <foo@meisterderspiele.de>)
Responses Re: How to insert a bulk of data with unique-violations very fast  (Torsten Zühlsdorff <foo@meisterderspiele.de>)
List pgsql-performance
> Within the data to import most rows have 20 till 50 duplicates. Sometime
> much more, sometimes less.

In that case (source data has lots of redundancy), after importing the
data chunks in parallel, you can run a first pass of de-duplication on the
chunks, also in parallel, something like :

CREATE TEMP TABLE foo_1_dedup AS SELECT DISTINCT * FROM foo_1;

or you could compute some aggregates, counts, etc. Same as before, no WAL
needed, and you can use all your cores in parallel.

 From what you say this should reduce the size of your imported data by a
lot (and hence the time spent in the non-parallel operation).

With a different distribution, ie duplicates only between existing and
imported data, and not within the imported data, this strategy would be
useless.


pgsql-performance by date:

Previous
From: Torsten Zühlsdorff
Date:
Subject: Re: How to insert a bulk of data with unique-violations very fast
Next
From: Torsten Zühlsdorff
Date:
Subject: Re: How to insert a bulk of data with unique-violations very fast