Skip to main content

Django backend for CockroachDB

Project description

CockroachDB backend for Django

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

pip install django-cockroachdb==2.2.*

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',
    }
}

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().

Known issues and limitations (as of cockroachdb 19.2.1)

  1. CockroachDB doesn't support savepoints. 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. CockroachDB can't disable constraint checking, which means certain things in Django like forward references in fixtures aren't supported.

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

    1. changing column type
    2. dropping or changing a table's primary key
  4. Incorrect queries:

    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.
  5. 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. extract() doesn't support interval columns (DurationField): unknown signature: extract(string, interval)
    7. The log() function doesn't support custom bases: unknown signature: extract(string, interval)
    8. sum() doesn't support arguments of different types: sum(): unsupported binary operator: <float> + <int>
    9. greatest() doesn't support arguments of different types: greatest(): expected <arg> to be of type <type>, found type <other type>
    10. Common aggregation queries fail: column must appear in the GROUP BY clause or be used in an aggregate function
    11. The isoyear lookup isn't supported: extract(): unsupported timespan: isoyear
    12. Using the avg() database function on an interval column (DurationField) isn't supported: unknown signature: avg(interval)
    13. 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-2.2a1.tar.gz (16.6 kB view details)

Uploaded Source

Built Distribution

django_cockroachdb-2.2a1-py3-none-any.whl (22.3 kB view details)

Uploaded Python 3

File details

Details for the file django-cockroachdb-2.2a1.tar.gz.

File metadata

  • Download URL: django-cockroachdb-2.2a1.tar.gz
  • Upload date:
  • Size: 16.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/42.0.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.0

File hashes

Hashes for django-cockroachdb-2.2a1.tar.gz
Algorithm Hash digest
SHA256 92d4642eb3e3caba512d6771612ad9c8821a508d7f1d4fc8ea08991c4e4228cc
MD5 d19ba2c46d639fcbd7711090968b78fa
BLAKE2b-256 f937acf73ff338169ba5c6a03fe87e34e2e1234c9af1946be525ad40ded186af

See more details on using hashes here.

File details

Details for the file django_cockroachdb-2.2a1-py3-none-any.whl.

File metadata

  • Download URL: django_cockroachdb-2.2a1-py3-none-any.whl
  • Upload date:
  • Size: 22.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/42.0.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.0

File hashes

Hashes for django_cockroachdb-2.2a1-py3-none-any.whl
Algorithm Hash digest
SHA256 bec7ee3a74e228e89b3e41b6af3810a412a6e670cc39e6a309fd272c03ec1738
MD5 93062a02d220148a8c5c433f94e2cf7a
BLAKE2b-256 236774a9446c560a860d167142862f4ac1a48ec42564a78b593067503df00b4e

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