Skip to main content

Django backend for CockroachDB

Project description

CockroachDB backend for Django

Prerequisites

You must install either:

The binary package is a practical choice for development and testing but in production it is advised to use the package built from sources.

Install and usage

Use the version of django-cockroachdb that corresponds to your version of Django. For example, to get the latest compatible release for Django 3.1.x:

pip install django-cockroachdb==3.1.*

The minor release number of Django doesn't correspond to the minor release number of django-cockroachdb. Use the latest minor release of each.

Configure the Django DATABASES setting similar to this:

DATABASES = {
    'default': {
        'ENGINE': 'django_cockroachdb',
        'NAME': 'django',
        'USER': 'myprojectuser',
        'PASSWORD': '',
        'HOST': 'localhost',
        'PORT': '26257',
        # If connecting with SSL, include the section below, replacing the
        # file paths as appropriate.
        'OPTIONS': {
            'sslmode': 'require',
            'sslrootcert': '/certs/ca.crt',
            # Either sslcert and sslkey (below) or PASSWORD (above) is
            # required.
            'sslcert': '/certs/client.myprojectuser.crt',
            'sslkey': '/certs/client.myprojectuser.key',
        },
    },
}

If using Kerberos authentication, you can specify a custom service name in 'OPTIONS' using the key 'krbsrvname'.

Notes on Django fields

  • IntegerField uses the same storage as BigIntegerField so IntegerField is introspected by inspectdb as BigIntegerField.

  • AutoField and BigAutoField are both stored as integer (64-bit) with DEFAULT unique_rowid().

Notes on Django QuerySets

  • QuerySet.explain() accepts verbose, types, opt, vec, and distsql options which correspond to CockroachDB's parameters. For example:

    >>> Choice.objects.explain(opt=True, verbose=True)
    'scan polls_choice\n ├── columns: id:1 question_id:4 choice_text:2 votes:3\n ├── stats: [rows=1]\n ├── cost: 1.1\n ├── key: (1)\n ├── fd: (1)-->(2-4)\n └── prune: (1-4)'
    

FAQ

Why do I get the error psycopg2.errors.InvalidName: no database specified?

You may need to create the database. You can use cockroach sql --insecure on the command line to get a SQL prompt.

GIS support

Starting with CockroachDB 20.2.x and django-cockroachdb 3.1.3, you can use django.contrib.gis with CockroachDB.

Use 'ENGINE': 'django_cockroachdb_gis' in Django's DATABASES setting.

You must install GEOS rather than have Django use the libgeos_c.so bundled with CockroachDB. In other words, if you try this Django setting:

GEOS_LIBRARY_PATH = '/usr/local/lib/cockroach/libgeos_c.so'

It will fail with OSError: libgeos.so.3.8.1: cannot open shared object file: No such file or directory.

Known issues and limitations (as of CockroachDB 20.2.4)

Additional limitations in CockroachDB 20.1.x

  • The StdDev and Variance aggregates aren't supported.

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-cockroachdb-3.1.3.tar.gz (21.0 kB view details)

Uploaded Source

Built Distribution

django_cockroachdb-3.1.3-py3-none-any.whl (27.3 kB view details)

Uploaded Python 3

File details

Details for the file django-cockroachdb-3.1.3.tar.gz.

File metadata

  • Download URL: django-cockroachdb-3.1.3.tar.gz
  • Upload date:
  • Size: 21.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.9.0

File hashes

Hashes for django-cockroachdb-3.1.3.tar.gz
Algorithm Hash digest
SHA256 fe7d60d23e203f076e515644546a7986e93149a0e0eea0cef00f761abb51c42e
MD5 12392e051e23623ec757674a9e471506
BLAKE2b-256 68167226dadbbb3d569f283714082d69112000be3728412e8c298a7af2a18db2

See more details on using hashes here.

File details

Details for the file django_cockroachdb-3.1.3-py3-none-any.whl.

File metadata

  • Download URL: django_cockroachdb-3.1.3-py3-none-any.whl
  • Upload date:
  • Size: 27.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.9.0

File hashes

Hashes for django_cockroachdb-3.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 57f99407b7d7eadc677d40af5682a93d8b220373311b1f3dddb040e89e4a4a40
MD5 9d3d768e13d01a3230b251004177d0a0
BLAKE2b-256 4d39645c162a722b1b0004da31141251e0c2a0b615e30a25c31b1d268c255dc1

See more details on using hashes here.

Supported by

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