1
0
mirror of https://github.com/django/django.git synced 2025-10-24 22:26:08 +00:00

queryset-refactor: Fixed a problem in the isnull=True handling.

git-svn-id: http://code.djangoproject.com/svn/django/branches/queryset-refactor@6490 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Malcolm Tredinnick
2007-10-14 02:14:15 +00:00
parent b47231ee3e
commit 2c4013e74f
2 changed files with 12 additions and 13 deletions

View File

@@ -546,7 +546,7 @@ class Query(object):
opts = self.model._meta opts = self.model._meta
alias = self.join((None, opts.db_table, None, None)) alias = self.join((None, opts.db_table, None, None))
dupe_multis = (connection == AND) dupe_multis = (connection == AND)
seen_aliases = [] join_list = []
done_split = not self.where done_split = not self.where
# FIXME: Using enumerate() here is expensive. We only need 'i' to # FIXME: Using enumerate() here is expensive. We only need 'i' to
@@ -558,20 +558,21 @@ class Query(object):
if name == 'pk': if name == 'pk':
name = target_field.name name = target_field.name
if joins is not None: if joins is not None:
seen_aliases.extend(joins) join_list.append(joins)
last = joins last = joins
alias = joins[-1] alias = joins[-1]
if connection == OR and not done_split: if connection == OR and not done_split:
if self.alias_map[joins[0]][ALIAS_REFCOUNT] == 1: if self.alias_map[joins[0]][ALIAS_REFCOUNT] == 1:
done_split = True done_split = True
self.promote_alias(joins[0]) self.promote_alias(joins[0])
all_aliases = []
for a in join_list:
all_aliases.extend(a)
for t in self.tables[1:]: for t in self.tables[1:]:
if t in seen_aliases: if t in all_aliases:
continue continue
self.promote_alias(t) self.promote_alias(t)
break break
else:
seen_aliases.extend(joins)
else: else:
# Normal field lookup must be the last field in the filter. # Normal field lookup must be the last field in the filter.
if i != len(parts) - 1: if i != len(parts) - 1:
@@ -580,13 +581,13 @@ class Query(object):
col = target_col or target_field.column col = target_col or target_field.column
if target_field is opts.pk and seen_aliases: if target_field is opts.pk and join_list:
# An optimization: if the final join is against a primary key, # An optimization: if the final join is against a primary key,
# we can go back one step in the join chain and compare against # we can go back one step in the join chain and compare against
# the lhs of the join instead. The result (potentially) involves # the lhs of the join instead. The result (potentially) involves
# one less table join. # one less table join.
self.unref_alias(alias) self.unref_alias(alias)
join = self.alias_map[seen_aliases[-1]][ALIAS_JOIN] join = self.alias_map[join_list[-1][-1]][ALIAS_JOIN]
alias = join[LHS_ALIAS] alias = join[LHS_ALIAS]
col = join[LHS_JOIN_COL] col = join[LHS_JOIN_COL]
@@ -595,12 +596,12 @@ class Query(object):
# join when connecting to the previous model. We make that # join when connecting to the previous model. We make that
# adjustment here. We don't do this unless needed because it's less # adjustment here. We don't do this unless needed because it's less
# efficient at the database level. # efficient at the database level.
self.promote_alias(joins[0]) self.promote_alias(join_list[-1][0])
self.where.add([alias, col, orig_field, lookup_type, value], self.where.add([alias, col, orig_field, lookup_type, value],
connection) connection)
if negate: if negate:
if seen_aliases: if join_list:
self.promote_alias(last[0]) self.promote_alias(last[0])
self.where.negate() self.where.negate()

View File

@@ -74,10 +74,8 @@ __test__ = {'API_TESTS':"""
Bug #1050 Bug #1050
>>> Item.objects.filter(tags__isnull=True) >>> Item.objects.filter(tags__isnull=True)
[<Item: three>] [<Item: three>]
>>> Item.objects.filter(tags__id__isnull=True)
# FIXME: Crashes! :-( [<Item: three>]
# >>> Item.objects.filter(tags__id__isnull=True)
# [<Item: three>]
Bug #1801 Bug #1801
>>> Author.objects.filter(item=i2) >>> Author.objects.filter(item=i2)