mirror of
https://github.com/django/django.git
synced 2025-07-04 17:59:13 +00:00
[soc2009/multidb] Modified using= arguments to default to None; modified querysets so you can track explicit database assignments. Patch from Russell Keith-Magee.
git-svn-id: http://code.djangoproject.com/svn/django/branches/soc2009/multidb@11893 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
562c5ffb07
commit
bdf21ccf8b
@ -48,7 +48,7 @@ class SiteProfileNotAvailable(Exception):
|
||||
pass
|
||||
|
||||
class PermissionManager(models.Manager):
|
||||
def get_by_natural_key(self, codename, app_label, model, using=DEFAULT_DB_ALIAS):
|
||||
def get_by_natural_key(self, codename, app_label, model, using=None):
|
||||
return self.using(using).get(
|
||||
codename=codename,
|
||||
content_type=ContentType.objects.get_by_natural_key(app_label, model)
|
||||
@ -106,7 +106,7 @@ class Group(models.Model):
|
||||
return self.name
|
||||
|
||||
class UserManager(models.Manager):
|
||||
def create_user(self, username, email, password=None, using=DEFAULT_DB_ALIAS):
|
||||
def create_user(self, username, email, password=None, using=None):
|
||||
"Creates and saves a User with the given username, e-mail and password."
|
||||
now = datetime.datetime.now()
|
||||
user = self.model(None, username, '', '', email.strip().lower(), 'placeholder', False, True, False, now, now)
|
||||
@ -117,7 +117,7 @@ class UserManager(models.Manager):
|
||||
user.save(using=using)
|
||||
return user
|
||||
|
||||
def create_superuser(self, username, email, password, using=DEFAULT_DB_ALIAS):
|
||||
def create_superuser(self, username, email, password, using=None):
|
||||
u = self.create_user(username, email, password)
|
||||
u.is_staff = True
|
||||
u.is_active = True
|
||||
|
@ -59,7 +59,7 @@ def sitemap(request, sitemaps, section=None):
|
||||
xml = smart_str(loader.render_to_string('gis/sitemaps/geo_sitemap.xml', {'urlset': urls}))
|
||||
return HttpResponse(xml, mimetype='application/xml')
|
||||
|
||||
def kml(request, label, model, field_name=None, compress=False, using=DEFAULT_DB_ALIAS):
|
||||
def kml(request, label, model, field_name=None, compress=False, using=None):
|
||||
"""
|
||||
This view generates KML for the given app label, model, and field name.
|
||||
|
||||
@ -83,15 +83,15 @@ def kml(request, label, model, field_name=None, compress=False, using=DEFAULT_DB
|
||||
|
||||
if connection.ops.postgis:
|
||||
# PostGIS will take care of transformation.
|
||||
placemarks = klass._default_manager.kml(field_name=field_name)
|
||||
placemarks = klass._default_manager.using(using).kml(field_name=field_name)
|
||||
else:
|
||||
# There's no KML method on Oracle or MySQL, so we use the `kml`
|
||||
# attribute of the lazy geometry instead.
|
||||
placemarks = []
|
||||
if connection.ops.oracle:
|
||||
qs = klass._default_manager.transform(4326, field_name=field_name)
|
||||
qs = klass._default_manager.using(using).transform(4326, field_name=field_name)
|
||||
else:
|
||||
qs = klass._default_manager.all()
|
||||
qs = klass._default_manager.using(using).all()
|
||||
for mod in qs:
|
||||
setattr(mod, 'kml', getattr(mod, field_name).kml)
|
||||
placemarks.append(mod)
|
||||
@ -103,7 +103,7 @@ def kml(request, label, model, field_name=None, compress=False, using=DEFAULT_DB
|
||||
render = render_to_kml
|
||||
return render('gis/kml/placemarks.kml', {'places' : placemarks})
|
||||
|
||||
def kmz(request, label, model, field_name=None, using=DEFAULT_DB_ALIAS):
|
||||
def kmz(request, label, model, field_name=None, using=None):
|
||||
"""
|
||||
This view returns KMZ for the given app label, model, and field name.
|
||||
"""
|
||||
|
@ -67,7 +67,7 @@ class LayerMapping(object):
|
||||
def __init__(self, model, data, mapping, layer=0,
|
||||
source_srs=None, encoding=None,
|
||||
transaction_mode='commit_on_success',
|
||||
transform=True, unique=None, using=DEFAULT_DB_ALIAS):
|
||||
transform=True, unique=None, using=None):
|
||||
"""
|
||||
A LayerMapping object is initialized using the given Model (not an instance),
|
||||
a DataSource (or string path to an OGR-supported data file), and a mapping
|
||||
|
@ -28,7 +28,7 @@ class QuerySet(object):
|
||||
def __init__(self, model=None, query=None, using=None):
|
||||
self.model = model
|
||||
# EmptyQuerySet instantiates QuerySet with model as None
|
||||
self.db = using or DEFAULT_DB_ALIAS
|
||||
self._db = using
|
||||
self.query = query or sql.Query(self.model)
|
||||
self._result_cache = None
|
||||
self._iter = None
|
||||
@ -688,7 +688,7 @@ class QuerySet(object):
|
||||
Selects which database this QuerySet should excecute it's query against.
|
||||
"""
|
||||
clone = self._clone()
|
||||
clone.db = alias
|
||||
clone._db = alias
|
||||
return clone
|
||||
|
||||
###################################
|
||||
@ -708,6 +708,11 @@ class QuerySet(object):
|
||||
return False
|
||||
ordered = property(ordered)
|
||||
|
||||
def db(self):
|
||||
"Return the database that will be used if this query is executed now"
|
||||
return self._db or DEFAULT_DB_ALIAS
|
||||
db = property(db)
|
||||
|
||||
###################
|
||||
# PRIVATE METHODS #
|
||||
###################
|
||||
@ -719,7 +724,7 @@ class QuerySet(object):
|
||||
if self._sticky_filter:
|
||||
query.filter_is_sticky = True
|
||||
c = klass(model=self.model, query=query)
|
||||
c.db = self.db
|
||||
c._db = self._db
|
||||
c.__dict__.update(kwargs)
|
||||
if setup and hasattr(c, '_setup_query'):
|
||||
c._setup_query()
|
||||
|
@ -57,7 +57,7 @@ class Tag(models.Model):
|
||||
self.tagged, self.name)
|
||||
|
||||
class PersonManager(models.Manager):
|
||||
def get_by_natural_key(self, name, using=DEFAULT_DB_ALIAS):
|
||||
def get_by_natural_key(self, name, using=None):
|
||||
return self.using(using).get(name=name)
|
||||
|
||||
class Person(models.Model):
|
||||
|
@ -83,7 +83,7 @@ class WidgetProxy(Widget):
|
||||
# Check for forward references in FKs and M2Ms with natural keys
|
||||
|
||||
class TestManager(models.Manager):
|
||||
def get_by_natural_key(self, key, using=DEFAULT_DB_ALIAS):
|
||||
def get_by_natural_key(self, key, using=None):
|
||||
return self.using(using).get(name=key)
|
||||
|
||||
class Store(models.Model):
|
||||
|
@ -107,7 +107,6 @@ class GenericAdminViewTest(TestCase):
|
||||
self.assertEquals(formset.forms[0].as_p(), '<p><label for="id_generic_inline_admin-media-content_type-object_id-0-url">Url:</label> <input id="id_generic_inline_admin-media-content_type-object_id-0-url" type="text" name="generic_inline_admin-media-content_type-object_id-0-url" value="http://example.com/logo.png" maxlength="200" /><input type="hidden" name="generic_inline_admin-media-content_type-object_id-0-id" value="2" id="id_generic_inline_admin-media-content_type-object_id-0-id" /></p>')
|
||||
self.assertEquals(formset.forms[1].as_p(), '<p><label for="id_generic_inline_admin-media-content_type-object_id-1-url">Url:</label> <input id="id_generic_inline_admin-media-content_type-object_id-1-url" type="text" name="generic_inline_admin-media-content_type-object_id-1-url" maxlength="200" /><input type="hidden" name="generic_inline_admin-media-content_type-object_id-1-id" id="id_generic_inline_admin-media-content_type-object_id-1-id" /></p>')
|
||||
|
||||
|
||||
def testGenericInlineFormsetFactory(self):
|
||||
# Regression test for #10522.
|
||||
inline_formset = generic_inlineformset_factory(Media,
|
||||
|
@ -17,7 +17,7 @@ class Review(models.Model):
|
||||
ordering = ('source',)
|
||||
|
||||
class PersonManager(models.Manager):
|
||||
def get_by_natural_key(self, name, using=DEFAULT_DB_ALIAS):
|
||||
def get_by_natural_key(self, name, using=None):
|
||||
return self.using(using).get(name=name)
|
||||
|
||||
class Person(models.Model):
|
||||
|
Loading…
x
Reference in New Issue
Block a user