1
0
mirror of https://github.com/django/django.git synced 2025-10-26 07:06:08 +00:00

[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

View File

@@ -7,6 +7,18 @@ module.
.. currentmodule:: django.contrib.postgres.fields .. 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`` ``ArrayField``
============== ==============
@@ -241,14 +253,6 @@ transform do not change. For example::
at the database level and cannot be supported in a logical, consistent at the database level and cannot be supported in a logical, consistent
fashion by Django. 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 ``CIText`` fields
================= =================