Django backend for CockroachDB
Project description
CockroachDB backend for Django
Prerequisites
You must install 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 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 asBigIntegerField
soIntegerField
is introspected byinspectdb
asBigIntegerField
. -
AutoField
andBigAutoField
are both stored as integer (64-bit) withDEFAULT unique_rowid()
.
Notes on Django QuerySets
-
QuerySet.explain()
acceptsverbose
,types
,opt
,vec
, anddistsql
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)
-
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
- dropping or changing a table's primary key
-
Known Bugs:
-
Unsupported queries:
- Mixed type addition in SELECT:
unsupported binary operator: <int> + <float>
- UPDATE float column with integer column:
value type int doesn't match type FLOAT8 of column <name>
- 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>
SmallAutoField
generates values that are too large for any corresponding foreign keys.- The
SHA224
andSHA384
database functions aren't supported.
- Mixed type addition in SELECT:
-
GIS:
- Some database functions aren't supported:
AsGML
,AsKML
,AsSVG
,BoundingCircle
,GeometryDistance
,LineLocatePoint
, andMemSize
. - The
Length
database function isn't supported on geodetic fields: st_lengthspheroid(): unimplemented. Union
may crash with unknown signature: st_union(geometry, geometry).- The spheroid argument of ST_DistanceSpheroid
isn't supported:
unknown signature: st_distancespheroid(geometry, geometry, string)
. - 3D storage isn't supported.
- These lookups aren't supported:
- Some database functions aren't supported:
Additional limitations in CockroachDB 20.1.x
- The
StdDev
andVariance
aggregates aren't supported.
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
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | fe7d60d23e203f076e515644546a7986e93149a0e0eea0cef00f761abb51c42e |
|
MD5 | 12392e051e23623ec757674a9e471506 |
|
BLAKE2b-256 | 68167226dadbbb3d569f283714082d69112000be3728412e8c298a7af2a18db2 |
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 57f99407b7d7eadc677d40af5682a93d8b220373311b1f3dddb040e89e4a4a40 |
|
MD5 | 9d3d768e13d01a3230b251004177d0a0 |
|
BLAKE2b-256 | 4d39645c162a722b1b0004da31141251e0c2a0b615e30a25c31b1d268c255dc1 |