[2.0.x] Fixed #28423 -- Expanded docs for indexing contrib.postgres fields.

Backport of 22ff4f81b1 from master
This commit is contained in:
Mads Jensen 2017-10-09 18:19:08 +02:00 committed by Tim Graham
parent 22bcb89917
commit d3e115151e
1 changed files with 12 additions and 8 deletions

View File

@ -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
=================