mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
Fixed #10913 -- Documented how related_name affects QuerySet filtering
Thanks neithere for the suggestion.
This commit is contained in:
@@ -1078,10 +1078,11 @@ define the details of how the relation works.
|
|||||||
.. attribute:: ForeignKey.related_name
|
.. attribute:: ForeignKey.related_name
|
||||||
|
|
||||||
The name to use for the relation from the related object back to this one.
|
The name to use for the relation from the related object back to this one.
|
||||||
See the :ref:`related objects documentation <backwards-related-objects>` for
|
It's also the default value for :attr:`related_query_name` (the name to use
|
||||||
a full explanation and example. Note that you must set this value
|
for the reverse filter name from the target model). See the :ref:`related
|
||||||
when defining relations on :ref:`abstract models
|
objects documentation <backwards-related-objects>` for a full explanation
|
||||||
<abstract-base-classes>`; and when you do so
|
and example. Note that you must set this value when defining relations on
|
||||||
|
:ref:`abstract models <abstract-base-classes>`; and when you do so
|
||||||
:ref:`some special syntax <abstract-related-name>` is available.
|
:ref:`some special syntax <abstract-related-name>` is available.
|
||||||
|
|
||||||
If you'd prefer Django not to create a backwards relation, set
|
If you'd prefer Django not to create a backwards relation, set
|
||||||
|
@@ -1124,8 +1124,9 @@ Example::
|
|||||||
>>> b.entry_set.filter(headline__contains='Lennon')
|
>>> b.entry_set.filter(headline__contains='Lennon')
|
||||||
>>> b.entry_set.count()
|
>>> b.entry_set.count()
|
||||||
|
|
||||||
You can override the ``FOO_set`` name by setting the ``related_name``
|
You can override the ``FOO_set`` name by setting the
|
||||||
parameter in the ``ForeignKey()`` definition. For example, if the ``Entry``
|
:attr:`~django.db.models.ForeignKey.related_name` parameter in the
|
||||||
|
:class:`~django.db.models.ForeignKey` definition. For example, if the ``Entry``
|
||||||
model was altered to ``blog = ForeignKey(Blog, related_name='entries')``, the
|
model was altered to ``blog = ForeignKey(Blog, related_name='entries')``, the
|
||||||
above example code would look like this::
|
above example code would look like this::
|
||||||
|
|
||||||
@@ -1224,10 +1225,11 @@ An example makes this easier to understand::
|
|||||||
a.entry_set.all() # Returns all Entry objects for this Author.
|
a.entry_set.all() # Returns all Entry objects for this Author.
|
||||||
|
|
||||||
Like :class:`~django.db.models.ForeignKey`,
|
Like :class:`~django.db.models.ForeignKey`,
|
||||||
:class:`~django.db.models.ManyToManyField` can specify ``related_name``. In the
|
:class:`~django.db.models.ManyToManyField` can specify
|
||||||
above example, if the :class:`~django.db.models.ManyToManyField` in ``Entry``
|
:attr:`~django.db.models.ManyToManyField.related_name`. In the above example,
|
||||||
had specified ``related_name='entries'``, then each ``Author`` instance would
|
if the :class:`~django.db.models.ManyToManyField` in ``Entry`` had specified
|
||||||
have an ``entries`` attribute instead of ``entry_set``.
|
``related_name='entries'``, then each ``Author`` instance would have an
|
||||||
|
``entries`` attribute instead of ``entry_set``.
|
||||||
|
|
||||||
One-to-one relationships
|
One-to-one relationships
|
||||||
------------------------
|
------------------------
|
||||||
|
Reference in New Issue
Block a user