Releases: AmbitionEng/django-pgbulk
Releases · AmbitionEng/django-pgbulk
3.2.2
Changes
- Use
cursor.connection
in psycopg2 to avoid issues caused by agents like NewRelic that wrap cursor objects by @wesleykendall in #51.
3.2.1
Changes
- Changed project ownership to
AmbitionEng
by @wesleykendall in #50.
3.2.0
Changes
- Added Python 3.13 support, dropped Python 3.8. Added Postgres17 support by @wesleykendall in #49.
3.1.0
Feature
- Add support for db defaults in
pgbulk.upsert
by @max-muoto in #42. - Support binary mode for
pgbulk.copy
by @max-muoto in #45.
3.0.2
3.0.1
Trivial
- Add overloads on
upsert
,aupsert
,update
, andaupdate
to improve type-checking onreturning=...
by @max-muoto in #40.
3.0.0
Breaking Changes
-
The
redundant_updates
flag forpgbulk.upsert
was renamed toignore_unchanged
, and the default behavior was flipped by @wesleykendall in #38.Unlike before, unchanged rows are not ignored by default. See the pull request for a guide on how to update invocations from version 2.
Features
-
Support update expressions,
returning
, andignore_unchanged
inpgbulk.update
by @wesleykendall in #38pgbulk.update
's interface has reached feature parity withpgbulk.upsert
, allowing for returning results, ignoring unchanged rows from being updated, and bulk updates with expressions. -
New
pgbulk.copy
function that leveragesCOPY ... FROM
by @wesleykendall in #39pgbulk.copy
wraps Postgres'sCOPY ... FROM
to insert data. Can be dramatically faster than Django'sbulk_create
.
Changes
- Django 5.1 compatibilty, dropped Django 3.2 / Postgres 12 support by @wesleykendall in #37.