mirror of
				https://github.com/django/django.git
				synced 2025-10-21 20:59:11 +00:00 
			
		
		
		
	Fixed #17930 -- Allowed ORing (|) with sliced QuerySets.
This commit is contained in:
		
							parent
							
								
									cd40306854
								
							
						
					
					
						commit
						e1fc07c047
					
				| @ -327,8 +327,11 @@ class QuerySet: | |||||||
|             return other |             return other | ||||||
|         if isinstance(other, EmptyQuerySet): |         if isinstance(other, EmptyQuerySet): | ||||||
|             return self |             return self | ||||||
|         combined = self._chain() |         query = self if self.query.can_filter() else self.model._base_manager.filter(pk__in=self.values('pk')) | ||||||
|  |         combined = query._chain() | ||||||
|         combined._merge_known_related_objects(other) |         combined._merge_known_related_objects(other) | ||||||
|  |         if not other.query.can_filter(): | ||||||
|  |             other = other.model._base_manager.filter(pk__in=other.values('pk')) | ||||||
|         combined.query.combine(other.query, sql.OR) |         combined.query.combine(other.query, sql.OR) | ||||||
|         return combined |         return combined | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2140,6 +2140,37 @@ class SubqueryTests(TestCase): | |||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @skipUnlessDBFeature('allow_sliced_subqueries_with_in') | ||||||
|  | class QuerySetBitwiseOperationTests(TestCase): | ||||||
|  |     @classmethod | ||||||
|  |     def setUpTestData(cls): | ||||||
|  |         school = School.objects.create() | ||||||
|  |         cls.room_1 = Classroom.objects.create(school=school, has_blackboard=False, name='Room 1') | ||||||
|  |         cls.room_2 = Classroom.objects.create(school=school, has_blackboard=True, name='Room 2') | ||||||
|  |         cls.room_3 = Classroom.objects.create(school=school, has_blackboard=True, name='Room 3') | ||||||
|  |         cls.room_4 = Classroom.objects.create(school=school, has_blackboard=False, name='Room 4') | ||||||
|  | 
 | ||||||
|  |     def test_or_with_rhs_slice(self): | ||||||
|  |         qs1 = Classroom.objects.filter(has_blackboard=True) | ||||||
|  |         qs2 = Classroom.objects.filter(has_blackboard=False)[:1] | ||||||
|  |         self.assertCountEqual(qs1 | qs2, [self.room_1, self.room_2, self.room_3]) | ||||||
|  | 
 | ||||||
|  |     def test_or_with_lhs_slice(self): | ||||||
|  |         qs1 = Classroom.objects.filter(has_blackboard=True)[:1] | ||||||
|  |         qs2 = Classroom.objects.filter(has_blackboard=False) | ||||||
|  |         self.assertCountEqual(qs1 | qs2, [self.room_1, self.room_2, self.room_4]) | ||||||
|  | 
 | ||||||
|  |     def test_or_with_both_slice(self): | ||||||
|  |         qs1 = Classroom.objects.filter(has_blackboard=False)[:1] | ||||||
|  |         qs2 = Classroom.objects.filter(has_blackboard=True)[:1] | ||||||
|  |         self.assertCountEqual(qs1 | qs2, [self.room_1, self.room_2]) | ||||||
|  | 
 | ||||||
|  |     def test_or_with_both_slice_and_ordering(self): | ||||||
|  |         qs1 = Classroom.objects.filter(has_blackboard=False).order_by('-pk')[:1] | ||||||
|  |         qs2 = Classroom.objects.filter(has_blackboard=True).order_by('-name')[:1] | ||||||
|  |         self.assertCountEqual(qs1 | qs2, [self.room_3, self.room_4]) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| class CloneTests(TestCase): | class CloneTests(TestCase): | ||||||
| 
 | 
 | ||||||
|     def test_evaluated_queryset_as_argument(self): |     def test_evaluated_queryset_as_argument(self): | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user