django1/django/db
Malcolm Tredinnick 7d9b29a56d Use plain model.Manager, or suitable proxy, for model saving.
We can't use the default manager in Model.save_base(), since we need to
retrieve existing objects which might be filtered out by that manager. We now
always use a plain Manager instance at that point (or something that can
replace it, such as a GeoManager), making all existing rows in the
database visible to the saving code.

The logic for detecting a "suitable replacement" plain base is the same as for
related fields: if the use_for_related_fields is set on the manager subclass,
we can use it. The general requirement here is that we want a base class that
returns the appropriate QuerySet subclass, but does not restrict the rows
returned.

Fixed #8990, #9527.

Refs #2698 (which is not fixed by this change, but it's the first part of a
larger change to fix that bug.)

git-svn-id: http://code.djangoproject.com/svn/django/trunk@10056 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2009-03-15 03:41:33 +00:00
..
backends Fixed #10488: fixed DB cache backend test failures in Oracle. 2009-03-13 21:04:48 +00:00
models Use plain model.Manager, or suitable proxy, for model saving. 2009-03-15 03:41:33 +00:00
__init__.py Improved the error message in case of an invalid DATABASE_BACKEND to ignore '.svn' directories in displaying the list of valid backends 2009-03-13 04:45:11 +00:00
transaction.py Fixed #3460 -- Added an ability to enable true autocommit for psycopg2 backend. 2009-03-11 07:06:50 +00:00