mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #17156 -- Added documentation examples for exists()
Thanks mrmagooey for the draft patch.
This commit is contained in:
		| @@ -31,6 +31,9 @@ You can evaluate a ``QuerySet`` in the following ways: | |||||||
|       for e in Entry.objects.all(): |       for e in Entry.objects.all(): | ||||||
|           print(e.headline) |           print(e.headline) | ||||||
|  |  | ||||||
|  |   Note: Don't use this if all you want to do is determine if at least one | ||||||
|  |   result exists. It's more efficient to use :meth:`~QuerySet.exists`. | ||||||
|  |  | ||||||
| * **Slicing.** As explained in :ref:`limiting-querysets`, a ``QuerySet`` can | * **Slicing.** As explained in :ref:`limiting-querysets`, a ``QuerySet`` can | ||||||
|   be sliced, using Python's array-slicing syntax. Slicing an unevaluated |   be sliced, using Python's array-slicing syntax. Slicing an unevaluated | ||||||
|   ``QuerySet`` usually returns another unevaluated ``QuerySet``, but Django |   ``QuerySet`` usually returns another unevaluated ``QuerySet``, but Django | ||||||
| @@ -75,7 +78,7 @@ You can evaluate a ``QuerySet`` in the following ways: | |||||||
|  |  | ||||||
|   Note: *Don't* use this if all you want to do is determine if at least one |   Note: *Don't* use this if all you want to do is determine if at least one | ||||||
|   result exists, and don't need the actual objects. It's more efficient to |   result exists, and don't need the actual objects. It's more efficient to | ||||||
|   use :meth:`exists() <QuerySet.exists>` (see below). |   use :meth:`~QuerySet.exists` (see below). | ||||||
|  |  | ||||||
| .. _pickling QuerySets: | .. _pickling QuerySets: | ||||||
|  |  | ||||||
| @@ -1268,7 +1271,7 @@ The :exc:`~django.core.exceptions.DoesNotExist` exception inherits from | |||||||
|         e = Entry.objects.get(id=3) |         e = Entry.objects.get(id=3) | ||||||
|         b = Blog.objects.get(id=1) |         b = Blog.objects.get(id=1) | ||||||
|     except ObjectDoesNotExist: |     except ObjectDoesNotExist: | ||||||
|         print("Either the entry or blog doesn't exist.") |         print "Either the entry or blog doesn't exist." | ||||||
|  |  | ||||||
| create | create | ||||||
| ~~~~~~ | ~~~~~~ | ||||||
| @@ -1523,9 +1526,40 @@ exists | |||||||
|  |  | ||||||
| Returns ``True`` if the :class:`.QuerySet` contains any results, and ``False`` | Returns ``True`` if the :class:`.QuerySet` contains any results, and ``False`` | ||||||
| if not. This tries to perform the query in the simplest and fastest way | if not. This tries to perform the query in the simplest and fastest way | ||||||
| possible, but it *does* execute nearly the same query. This means that calling | possible, but it *does* execute nearly the same query as a normal | ||||||
| :meth:`.QuerySet.exists` is faster than ``bool(some_query_set)``, but not by | :class:`.QuerySet` query. | ||||||
| a large degree. If ``some_query_set`` has not yet been evaluated, but you know |  | ||||||
|  | :meth:`~.QuerySet.exists` is useful for searches relating to both | ||||||
|  | object membership in a :class:`.QuerySet` and to the existence of any objects in | ||||||
|  | a :class:`.QuerySet`, particularly in the context of a large :class:`.QuerySet`. | ||||||
|  |  | ||||||
|  | The most efficient method of finding whether a model with a unique field | ||||||
|  | (e.g. ``primary_key``) is a member of a :class:`.QuerySet` is:: | ||||||
|  |  | ||||||
|  |     entry = Entry.objects.get(pk=123) | ||||||
|  |     if some_query_set.filter(pk=entry.pk).exists(): | ||||||
|  |         print "Entry contained in queryset" | ||||||
|  |  | ||||||
|  | Which will be faster than the following which requires evaluating and iterating | ||||||
|  | through the entire queryset:: | ||||||
|  |  | ||||||
|  |     if entry in some_query_set: | ||||||
|  |        print "Entry contained in QuerySet" | ||||||
|  |  | ||||||
|  | And to find whether a queryset contains any items:: | ||||||
|  |  | ||||||
|  |     if some_query_set.exists(): | ||||||
|  |         print "There is at least one object in some_query_set" | ||||||
|  |  | ||||||
|  | Which will be faster than:: | ||||||
|  |  | ||||||
|  |     if some_query_set: | ||||||
|  |         print "There is at least one object in some_query_set" | ||||||
|  |  | ||||||
|  | ... but not by a large degree (hence needing a large queryset for efficiency | ||||||
|  | gains). | ||||||
|  |  | ||||||
|  | Additionally, if a ``some_query_set`` has not yet been evaluated, but you know | ||||||
| that it will be at some point, then using ``some_query_set.exists()`` will do | that it will be at some point, then using ``some_query_set.exists()`` will do | ||||||
| more overall work (one query for the existence check plus an extra one to later | more overall work (one query for the existence check plus an extra one to later | ||||||
| retrieve the results) than simply using ``bool(some_query_set)``, which | retrieve the results) than simply using ``bool(some_query_set)``, which | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user