Fixed #7076 -- Include NULL values when excluding non-NULL items.
Based on a patch from emulbreh. git-svn-id: http://code.djangoproject.com/svn/django/trunk@7760 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
2c08986f44
commit
e41df5adcc
|
@ -1045,17 +1045,27 @@ class Query(object):
|
||||||
self.promote_alias(table)
|
self.promote_alias(table)
|
||||||
|
|
||||||
self.where.add((alias, col, field, lookup_type, value), connector)
|
self.where.add((alias, col, field, lookup_type, value), connector)
|
||||||
|
|
||||||
if negate:
|
if negate:
|
||||||
for alias in join_list:
|
for alias in join_list:
|
||||||
self.promote_alias(alias)
|
self.promote_alias(alias)
|
||||||
if final > 1 and lookup_type != 'isnull':
|
if lookup_type != 'isnull':
|
||||||
for alias in join_list:
|
if final > 1:
|
||||||
if self.alias_map[alias] == self.LOUTER:
|
for alias in join_list:
|
||||||
j_col = self.alias_map[alias][RHS_JOIN_COL]
|
if self.alias_map[alias][JOIN_TYPE] == self.LOUTER:
|
||||||
entry = Node([(alias, j_col, None, 'isnull', True)])
|
j_col = self.alias_map[alias][RHS_JOIN_COL]
|
||||||
entry.negate()
|
entry = Node([(alias, j_col, None, 'isnull', True)])
|
||||||
self.where.add(entry, AND)
|
entry.negate()
|
||||||
break
|
self.where.add(entry, AND)
|
||||||
|
break
|
||||||
|
elif not (lookup_type == 'in' and not value):
|
||||||
|
# Leaky abstraction artifact: We have to specifically
|
||||||
|
# exclude the "foo__in=[]" case from this handling, because
|
||||||
|
# it's short-circuited in the Where class.
|
||||||
|
entry = Node([(alias, col, field, 'isnull', True)])
|
||||||
|
entry.negate()
|
||||||
|
self.where.add(entry, AND)
|
||||||
|
|
||||||
if can_reuse is not None:
|
if can_reuse is not None:
|
||||||
can_reuse.update(join_list)
|
can_reuse.update(join_list)
|
||||||
|
|
||||||
|
|
|
@ -756,5 +756,11 @@ select_related(). We used to return the parent's Detail record here by mistake.
|
||||||
>>> obj.person.details.data
|
>>> obj.person.details.data
|
||||||
u'd2'
|
u'd2'
|
||||||
|
|
||||||
|
Bug #7076 -- excluding shouldn't eliminate NULL entries.
|
||||||
|
>>> Item.objects.exclude(modified=time1).order_by('name')
|
||||||
|
[<Item: four>, <Item: three>, <Item: two>]
|
||||||
|
>>> Tag.objects.exclude(parent__name=t1.name)
|
||||||
|
[<Tag: t1>, <Tag: t4>, <Tag: t5>]
|
||||||
|
|
||||||
"""}
|
"""}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue