Django backend for CockroachDB
Project description
CockroachDB backend for Django
Prerequisites
You must install:
- psycopg, which may have some prerequisites depending on which version you use.
You can also use either:
-
psycopg2, which has some prerequisites of its own.
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 6.0.x:
pip install django-cockroachdb==6.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': 'myprojectuser',
'PASSWORD': '',
'HOST': 'localhost',
'PORT': '26257',
# If connecting with SSL, include the section below, replacing the
# file paths as appropriate.
'OPTIONS': {
'sslmode': 'verify-full',
'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 applicable
'options': '--cluster={routing-id}',
},
},
}
If using Kerberos authentication, you can specify a custom service name in
'OPTIONS' using the key 'krbsrvname'.
Notes on Django fields
-
IntegerFielduses the same storage asBigIntegerFieldsoIntegerFieldis introspected byinspectdbasBigIntegerField. -
AutoFieldandBigAutoFieldare both stored as integer (64-bit) withDEFAULT unique_rowid().
Notes on Django QuerySets
-
QuerySet.explain()acceptsverbose,types,opt,vec, anddistsqloptions 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
GIS support
To use django.contrib.gis with CockroachDB, use
'ENGINE': 'django_cockroachdb_gis' in Django's DATABASES setting.
Disabling CockroachDB telemetry
By default, CockroachDB sends the version of django-cockroachdb that you're
using back to Cockroach Labs. To disable this, set
DISABLE_COCKROACHDB_TELEMETRY = True in your Django settings.
Known issues and limitations in CockroachDB 25.4.x and earlier
-
CockroachDB can't disable constraint checking, which means certain things in Django like forward references in fixtures aren't supported.
-
Migrations have some limitations. CockroachDB doesn't support:
- changing column type if it's part of an index
- dropping or changing a table's primary key
-
The
Field.db_commentandMeta.db_table_commentoptions aren't supported due to poor performance. -
Unsupported queries:
- Mixed type addition in SELECT:
unsupported binary operator: <int> + <float> - Division that yields a different type:
unsupported binary operator: <int> / <int> (desired <int>) - The power() database function doesn't accept negative exponents:
power(): integer out of range - sum() doesn't support arguments of different types:
sum(): unsupported binary operator: <float> + <int> - greatest() doesn't support arguments of different types:
greatest(): expected <arg> to be of type <type>, found type <other type> SmallAutoFieldgenerates values that are too large for any corresponding foreign keys.
- Mixed type addition in SELECT:
-
GIS:
- Some database functions aren't supported:
AsGML,AsKML,AsSVG, andGeometryDistance. - Some 3D functions or signatures aren't supported:
ST_3DPerimeter,ST_3DExtent,ST_Scale, andST_LengthSpheroid. - The
Lengthdatabase function isn't supported on geodetic fields: st_lengthspheroid(): unimplemented. Unionmay crash with unknown signature: st_union(geometry, geometry).- The spheroid argument of ST_DistanceSpheroid
isn't supported:
unknown signature: st_distancespheroid(geometry, geometry, string). - These lookups aren't supported:
- Some database functions aren't supported:
Known issues and limitations in CockroachDB 24.3.x and earlier
- CockroachDB executes
ALTER COLUMNqueries asynchronously which is at odds with Django's assumption that the database is altered before the next migration operation begins. CockroachDB will give an error likeunimplemented: table <...> is currently undergoing a schema changeif a later operation tries to modify the table before the asynchronous query finishes.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file django_cockroachdb-6.0.tar.gz.
File metadata
- Download URL: django_cockroachdb-6.0.tar.gz
- Upload date:
- Size: 24.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
44ab0f0697e6af78a22311e8ab08246a27fa850d2e22e3769fcb4aa25836ca0d
|
|
| MD5 |
e4f9290333e9b42c1766fe31bc29efbb
|
|
| BLAKE2b-256 |
4e4193e438a977b69a2afda82765ad432b62060c98bdea900f22e34ff056c853
|
File details
Details for the file django_cockroachdb-6.0-py3-none-any.whl.
File metadata
- Download URL: django_cockroachdb-6.0-py3-none-any.whl
- Upload date:
- Size: 27.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1026ee6ffa0d6319b8f166e2a02db2a6086537ba83aeee18dbfceea715fb425b
|
|
| MD5 |
5303da84fda26f45a61c02af3f4c1946
|
|
| BLAKE2b-256 |
f23843070374050bd480db410353a6c0b73ed0d579c8f2f0359c95ae7a8a4274
|