[1.5.x] Fixed #20243 - Clarified when RelatedManager.remove() exists.

Backport of 712a792713 from master
This commit is contained in:
Tim Graham 2013-04-11 14:13:09 -04:00
parent 93231851f8
commit 709ee83cd3
1 changed files with 7 additions and 8 deletions

View File

@ -82,14 +82,13 @@ Related objects reference
>>> e = Entry.objects.get(id=234) >>> e = Entry.objects.get(id=234)
>>> b.entry_set.remove(e) # Disassociates Entry e from Blog b. >>> b.entry_set.remove(e) # Disassociates Entry e from Blog b.
In order to prevent database inconsistency, this method only exists on For :class:`~django.db.models.ForeignKey` objects, this method only
:class:`~django.db.models.ForeignKey` objects where ``null=True``. If exists if ``null=True``. If the related field can't be set to ``None``
the related field can't be set to ``None`` (``NULL``), then an object (``NULL``), then an object can't be removed from a relation without
can't be removed from a relation without being added to another. In the being added to another. In the above example, removing ``e`` from
above example, removing ``e`` from ``b.entry_set()`` is equivalent to ``b.entry_set()`` is equivalent to doing ``e.blog = None``, and because
doing ``e.blog = None``, and because the ``blog`` the ``blog`` :class:`~django.db.models.ForeignKey` doesn't have
:class:`~django.db.models.ForeignKey` doesn't have ``null=True``, this ``null=True``, this is invalid.
is invalid.
.. method:: clear() .. method:: clear()