Skip to main content

Native postgres bulk update and upsert operations.

Project description

django-pgbulk

django-pgbulk provides functions for doing native Postgres bulk upserts (i.e. UPDATE ON CONFLICT) and bulk updates.

Bulk upserts can distinguish between updated and created rows and optionally ignore redundant updates.

Bulk updates are true bulk updates, unlike Django's bulk_update which can still suffer from O(N) queries and can create poor locking scenarios.

Quick Start

Do a bulk upsert on a model:

import pgbulk

pgbulk.upsert(
    MyModel,
    [
        MyModel(int_field=1, some_attr="some_val1"),
        MyModel(int_field=2, some_attr="some_val2"),
    ],
    # These are the fields that identify the uniqueness constraint.
    ["int_field"],
    # These are the fields that will be updated if the row already
    # exists. If not provided, all fields will be updated
    ["some_attr"]
)

Do a bulk update on a model:

import pgbulk

pgbulk.update(
    MyModel,
    [
        MyModel(id=1, some_attr='some_val1'),
        MyModel(id=2, some_attr='some_val2')
    ],
    # These are the fields that will be updated. If not provided,
    # all fields will be updated
    ['some_attr']
)

View the django-pgbulk docs for more information.

Compatibility

django-pgbulk is compatible with Python 3.8 - 3.12, Django 3.2 - 5.0, Psycopg 2 - 3, and Postgres 12 - 16.

Documentation

View the django-pgbulk docs here

Installation

Install django-pgbulk with:

pip3 install django-pgbulk

After this, add pgbulk to the INSTALLED_APPS setting of your Django project.

Contributing Guide

For information on setting up django-pgbulk for development and contributing changes, view CONTRIBUTING.md.

Creators

Other Contributors

  • @max-muoto
  • @dalberto

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django_pgbulk-2.4.0.tar.gz (9.9 kB view details)

Uploaded Source

Built Distribution

django_pgbulk-2.4.0-py3-none-any.whl (9.8 kB view details)

Uploaded Python 3

File details

Details for the file django_pgbulk-2.4.0.tar.gz.

File metadata

  • Download URL: django_pgbulk-2.4.0.tar.gz
  • Upload date:
  • Size: 9.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.3 Linux/5.15.0-1056-aws

File hashes

Hashes for django_pgbulk-2.4.0.tar.gz
Algorithm Hash digest
SHA256 e42b93d1b8b86e45c3f4731cc044a6cc58c8d0ee5c9697af028ac11484c9c200
MD5 242d4729790b6c94754d33d5c61b5515
BLAKE2b-256 1174d9857a37d4ec6d635a0cca1e86568d0a154db2d8a9e1eb9540288e0279a2

See more details on using hashes here.

File details

Details for the file django_pgbulk-2.4.0-py3-none-any.whl.

File metadata

  • Download URL: django_pgbulk-2.4.0-py3-none-any.whl
  • Upload date:
  • Size: 9.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.3 Linux/5.15.0-1056-aws

File hashes

Hashes for django_pgbulk-2.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 045f137a6107d028340df547334060e6edaefd842f9be30ec3b9ea700c7e19dc
MD5 b2f3abf17f95797d8a225e7a900f4181
BLAKE2b-256 095fef08f2728ab3c638a63053566b6563b11d7c3c8add567c4fa2af006fb4d2

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page