mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Fixed #29547 -- Added support for partial indexes.
Thanks to Ian Foote, Mariusz Felisiak, Simon Charettes, and Markus Holtermann for comments and feedback.
This commit is contained in:
@@ -21,7 +21,7 @@ options`_.
|
||||
``Index`` options
|
||||
=================
|
||||
|
||||
.. class:: Index(fields=(), name=None, db_tablespace=None, opclasses=())
|
||||
.. class:: Index(fields=(), name=None, db_tablespace=None, opclasses=(), condition=None)
|
||||
|
||||
Creates an index (B-Tree) in the database.
|
||||
|
||||
@@ -92,3 +92,44 @@ opclasses=['jsonb_path_ops'])`` creates a gin index on ``jsonfield`` using
|
||||
``opclasses`` are ignored for databases besides PostgreSQL.
|
||||
|
||||
:attr:`Index.name` is required when using ``opclasses``.
|
||||
|
||||
``condition``
|
||||
-------------
|
||||
|
||||
.. attribute:: Index.condition
|
||||
|
||||
.. versionadded:: 2.2
|
||||
|
||||
If the table is very large and your queries mostly target a subset of rows,
|
||||
it may be useful to restrict an index to that subset. Specify a condition as a
|
||||
:class:`~django.db.models.Q`. For example, ``condition=Q(pages__gt=400)``
|
||||
indexes records with more than 400 pages.
|
||||
|
||||
:attr:`Index.name` is required when using ``condition``.
|
||||
|
||||
.. admonition:: Restrictions on PostgreSQL
|
||||
|
||||
PostgreSQL requires functions referenced in the condition to be be marked as
|
||||
IMMUTABLE. Django doesn't validate this but PostgreSQL will error. This
|
||||
means that functions such as :ref:`date-functions` and
|
||||
:class:`~django.db.models.functions.Concat` aren't accepted. If you store
|
||||
dates in :class:`~django.db.models.DateTimeField`, comparison to
|
||||
:class:`~datetime.datetime` objects may require the ``tzinfo`` argument
|
||||
to be provided because otherwise the comparison could result in a mutable
|
||||
function due to the casting Django does for :ref:`lookups <field-lookups>`.
|
||||
|
||||
.. admonition:: Restrictions on SQLite
|
||||
|
||||
SQLite `imposes restrictions <https://www.sqlite.org/partialindex.html>`_
|
||||
on how a partial index can be constructed.
|
||||
|
||||
.. admonition:: Oracle
|
||||
|
||||
Oracle does not support partial indexes. Instead, partial indexes can be
|
||||
emulated using functional indexes. Use a :doc:`migration
|
||||
</topics/migrations>` to add the index using :class:`.RunSQL`.
|
||||
|
||||
.. admonition:: MySQL and MariaDB
|
||||
|
||||
The ``condition`` argument is ignored with MySQL and MariaDB as neither
|
||||
supports conditional indexes.
|
||||
|
@@ -201,6 +201,8 @@ Models
|
||||
|
||||
* Added support for PostgreSQL operator classes (:attr:`.Index.opclasses`).
|
||||
|
||||
* Added support for partial indexes (:attr:`.Index.condition`).
|
||||
|
||||
* Added many :ref:`math database functions <math-functions>`.
|
||||
|
||||
* Setting the new ``ignore_conflicts`` parameter of
|
||||
@@ -288,6 +290,9 @@ Database backend API
|
||||
|
||||
* ``DatabaseFeatures.uses_savepoints`` now defaults to ``True``.
|
||||
|
||||
* Third party database backends must implement support for partial indexes or
|
||||
set ``DatabaseFeatures.supports_partial_indexes`` to ``False``.
|
||||
|
||||
:mod:`django.contrib.gis`
|
||||
-------------------------
|
||||
|
||||
|
Reference in New Issue
Block a user