mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Fixed #34779 -- Avoided unnecessary selection of non-nullable m2m fields without natural keys during serialization.
By using `select_related(None)` instead of `select_related()`, the
unnecessary joins are completely avoided. Note that the current tests
already covers the change, when the field is not `null=True`.
Regression in f9936deed1.
			
			
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							6b965c6000
						
					
				
				
					commit
					517d3bb4dd
				
			| @@ -80,7 +80,10 @@ class Serializer(base.Serializer): | |||||||
|  |  | ||||||
|                 def queryset_iterator(obj, field): |                 def queryset_iterator(obj, field): | ||||||
|                     return ( |                     return ( | ||||||
|                         getattr(obj, field.name).select_related().only("pk").iterator() |                         getattr(obj, field.name) | ||||||
|  |                         .select_related(None) | ||||||
|  |                         .only("pk") | ||||||
|  |                         .iterator() | ||||||
|                     ) |                     ) | ||||||
|  |  | ||||||
|             m2m_iter = getattr(obj, "_prefetched_objects_cache", {}).get( |             m2m_iter = getattr(obj, "_prefetched_objects_cache", {}).get( | ||||||
|   | |||||||
| @@ -156,7 +156,10 @@ class Serializer(base.Serializer): | |||||||
|  |  | ||||||
|                 def queryset_iterator(obj, field): |                 def queryset_iterator(obj, field): | ||||||
|                     return ( |                     return ( | ||||||
|                         getattr(obj, field.name).select_related().only("pk").iterator() |                         getattr(obj, field.name) | ||||||
|  |                         .select_related(None) | ||||||
|  |                         .only("pk") | ||||||
|  |                         .iterator() | ||||||
|                     ) |                     ) | ||||||
|  |  | ||||||
|             m2m_iter = getattr(obj, "_prefetched_objects_cache", {}).get( |             m2m_iter = getattr(obj, "_prefetched_objects_cache", {}).get( | ||||||
|   | |||||||
| @@ -16,3 +16,7 @@ Bugfixes | |||||||
| * Fixed a bug in Django 4.2 where the deprecated ``DEFAULT_FILE_STORAGE`` and | * Fixed a bug in Django 4.2 where the deprecated ``DEFAULT_FILE_STORAGE`` and | ||||||
|   ``STATICFILES_STORAGE`` settings were not synced with ``STORAGES`` |   ``STATICFILES_STORAGE`` settings were not synced with ``STORAGES`` | ||||||
|   (:ticket:`34773`). |   (:ticket:`34773`). | ||||||
|  |  | ||||||
|  | * Fixed a regression in Django 4.2.2 that caused an unnecessary selection of a | ||||||
|  |   non-nullable ``ManyToManyField`` without a natural key during serialization | ||||||
|  |   (:ticket:`34779`). | ||||||
|   | |||||||
| @@ -60,7 +60,7 @@ class TopicManager(models.Manager): | |||||||
|  |  | ||||||
| class Topic(models.Model): | class Topic(models.Model): | ||||||
|     name = models.CharField(max_length=255) |     name = models.CharField(max_length=255) | ||||||
|     category = models.ForeignKey(Category, models.CASCADE, null=True) |     category = models.ForeignKey(Category, models.CASCADE) | ||||||
|     objects = TopicManager() |     objects = TopicManager() | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user