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 | ||||
|  | ||||
| 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 | ||||
| ================= | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user