mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	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:
		| @@ -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>] | ||||||
|  |  | ||||||
| """} | """} | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user