mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #28423 -- Expanded docs for indexing contrib.postgres fields.
This commit is contained in:
		| @@ -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 | ||||||
| ================= | ================= | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user