mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #10202 -- Fixed another couple of slicing edge-cases with querysets.
Patch from Alex Gaynor and Ramiro Morales. git-svn-id: http://code.djangoproject.com/svn/django/trunk@9924 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -345,7 +345,7 @@ class BaseQuery(object): | |||||||
|         # in SQL (in variants that provide them) doesn't change the COUNT |         # in SQL (in variants that provide them) doesn't change the COUNT | ||||||
|         # output. |         # output. | ||||||
|         number = max(0, number - self.low_mark) |         number = max(0, number - self.low_mark) | ||||||
|         if self.high_mark: |         if self.high_mark is not None: | ||||||
|             number = min(number, self.high_mark - self.low_mark) |             number = min(number, self.high_mark - self.low_mark) | ||||||
|  |  | ||||||
|         return number |         return number | ||||||
| @@ -1760,7 +1760,7 @@ class BaseQuery(object): | |||||||
|  |  | ||||||
|         Typically, this means no limits or offsets have been put on the results. |         Typically, this means no limits or offsets have been put on the results. | ||||||
|         """ |         """ | ||||||
|         return not (self.low_mark or self.high_mark) |         return not self.low_mark and self.high_mark is None | ||||||
|  |  | ||||||
|     def clear_select_fields(self): |     def clear_select_fields(self): | ||||||
|         """ |         """ | ||||||
|   | |||||||
| @@ -903,11 +903,17 @@ used in lookups. | |||||||
| >>> Item.objects.filter(created__in=[time1, time2]) | >>> Item.objects.filter(created__in=[time1, time2]) | ||||||
| [<Item: one>, <Item: two>] | [<Item: one>, <Item: two>] | ||||||
|  |  | ||||||
| Bug #7698 -- People like to slice with '0' as the high-water mark. | Bug #7698, #10202 -- People like to slice with '0' as the high-water mark. | ||||||
| >>> Item.objects.all()[0:0] | >>> Item.objects.all()[0:0] | ||||||
| [] | [] | ||||||
| >>> Item.objects.all()[0:0][:10] | >>> Item.objects.all()[0:0][:10] | ||||||
| [] | [] | ||||||
|  | >>> Item.objects.all()[:0].count() | ||||||
|  | 0 | ||||||
|  | >>> Item.objects.all()[:0].latest('created') | ||||||
|  | Traceback (most recent call last): | ||||||
|  |     ... | ||||||
|  | AssertionError: Cannot change a query once a slice has been taken. | ||||||
|  |  | ||||||
| Bug #7411 - saving to db must work even with partially read result set in | Bug #7411 - saving to db must work even with partially read result set in | ||||||
| another cursor. | another cursor. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user