mirror of https://github.com/django/django.git
[2.0.x] Fixed #28423 -- Expanded docs for indexing contrib.postgres fields.
Backport of 22ff4f81b1
from master
This commit is contained in:
parent
22bcb89917
commit
d3e115151e
|
@ -7,6 +7,18 @@ module.
|
|||
|
||||
.. currentmodule:: django.contrib.postgres.fields
|
||||
|
||||
Indexing these fields
|
||||
=====================
|
||||
|
||||
:class:`~django.db.models.Index` and :attr:`.Field.db_index` both create a
|
||||
B-tree index, which isn't particularly helpful when querying complex data types.
|
||||
Indexes such as :class:`~django.contrib.postgres.indexes.GinIndex` and
|
||||
:class:`~django.contrib.postgres.indexes.GistIndex` are better suited, though
|
||||
the index choice is dependent on the queries that you're using. Generally, GiST
|
||||
may be a good choice for the :ref:`range fields <range-fields>` and
|
||||
:class:`HStoreField`, and GIN may be helpful for :class:`ArrayField` and
|
||||
:class:`JSONField`.
|
||||
|
||||
``ArrayField``
|
||||
==============
|
||||
|
||||
|
@ -241,14 +253,6 @@ transform do not change. For example::
|
|||
at the database level and cannot be supported in a logical, consistent
|
||||
fashion by Django.
|
||||
|
||||
Indexing ``ArrayField``
|
||||
-----------------------
|
||||
|
||||
At present using :attr:`~django.db.models.Field.db_index` will create a
|
||||
``btree`` index. This does not offer particularly significant help to querying.
|
||||
A more useful index is a ``GIN`` index, which you should create using a
|
||||
:class:`~django.db.migrations.operations.RunSQL` operation.
|
||||
|
||||
``CIText`` fields
|
||||
=================
|
||||
|
||||
|
|
Loading…
Reference in New Issue