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.0.x:

pip install django-cockroachdb==3.0.*

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': 'root',
        'PASSWORD': '',
        'HOST': 'localhost',
        'PORT': '26257',
        # If connecting with SSL, remove the PASSWORD entry above and include
        # the section below, replacing the file paths as appropriate.
        'OPTIONS': {
            'sslmode': 'require',
            'sslrootcert': '/certs/ca.crt',
            'sslcert': '/certs/client.myprojectuser.crt',
            'sslkey': '/certs/client.myprojectuser.key',
        },
    },
}

Notes on Django fields

  1. CharField's max_length is ignored. It uses the same storage as TextField so CharField is introspected by inspectdb as TextField.

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

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

Notes on Django QuerySets

  1. 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.

Known issues and limitations (as of CockroachDB 20.1.4)

  1. CockroachDB can't disable constraint checking, which means certain things in Django like forward references in fixtures aren't supported.

  2. Migrations have some limitations. CockroachDB doesn't support:

    1. changing column type
    2. dropping or changing a table's primary key
  3. Known Bugs:

    1. Timezones after 2038 use incorrect DST settings.
  4. Unsupported queries:

    1. Mixed type addition in SELECT: unsupported binary operator: <int> + <float>
    2. UPDATE float column with integer column: value type int doesn't match type FLOAT8 of column <name>
    3. Division that yields a different type: unsupported binary operator: <int> / <int> (desired <int>)
    4. The power() database function doesn't accept negative exponents: power(): integer out of range
    5. The StdDev and Variance aggregates aren't supported.
    6. sum() doesn't support arguments of different types: sum(): unsupported binary operator: <float> + <int>
    7. greatest() doesn't support arguments of different types: greatest(): expected <arg> to be of type <type>, found type <other type>
    8. SmallAutoField generates values that are too large for any corresponding foreign keys.
    9. The SHA224 and SHA384 database functions aren't supported.

Additional issues and limitations in CockroachDB 19.2.x (as of 19.2.9)

  1. Savepoints aren't supported. This means a few things:

    1. Django's transaction.atomic() can't be nested.
    2. Django's TestCase works like TransactionTestCase. That is, transactions aren't used to speed up the former.
  2. Known Bugs:

    1. The extract() function doesn't respect the time zone.
    2. Interval math across daylight saving time is incorrect.
    3. date_trunc('week', <value>) truncates to midnight Sunday rather than Monday
    4. date_trunc() results are incorrectly localized.
    5. cast() timestamptz to time doesn't respect the time zone.
    6. Interval math may be incorrect on date columns.
  3. Unsupported queries:

    1. extract() doesn't support interval columns (DurationField): unknown signature: extract(string, interval)
    2. The log() function doesn't support custom bases: unknown signature: extract(string, interval)
    3. timezone() doesn't support UTC offsets: timezone(): unknown time zone UTC...

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.0.2.tar.gz (19.8 kB view details)

Uploaded Source

Built Distribution

django_cockroachdb-3.0.2-py3-none-any.whl (24.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: django-cockroachdb-3.0.2.tar.gz
  • Upload date:
  • Size: 19.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for django-cockroachdb-3.0.2.tar.gz
Algorithm Hash digest
SHA256 c04713e3f7a8c24b303820f74c24f01d93b634be1fc8bc414e118664da934c87
MD5 1d59d2bd4b1c208ea283e3a0bd134d65
BLAKE2b-256 cd91c162a44b69ddb6c8182477c54b0855dd0852639b703ccefeb9c83850a75b

See more details on using hashes here.

File details

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

File metadata

  • Download URL: django_cockroachdb-3.0.2-py3-none-any.whl
  • Upload date:
  • Size: 24.7 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/49.2.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for django_cockroachdb-3.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 16011e774d48b77acc5f341774424961d912264b7ff720483110f0a8120e0691
MD5 af9de4a41fd8f6c096a29afedebb7c8c
BLAKE2b-256 1d2fa1c31b5437860435679def77258c8e0320516d48102c7f2f9e116d194864

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