Fixed #33003 -- Removed **kwargs from QuerySet._chain().

The functionality of updating the __dict__ was only present to allow
for pickling a Prefetch object, which is a comparably rare operation.
Forcing the __getstate__() implementation to handle it allows the
chaining operation to be slightly faster, which is much more common.
This commit is contained in:
Keryn Knight 2021-08-09 12:28:40 +01:00 committed by GitHub
parent fffeb5df55
commit 921e4ccb77
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 5 additions and 6 deletions

View File

@ -1322,7 +1322,7 @@ class QuerySet:
self._insert(item, fields=fields, using=self.db, ignore_conflicts=ignore_conflicts) self._insert(item, fields=fields, using=self.db, ignore_conflicts=ignore_conflicts)
return inserted_rows return inserted_rows
def _chain(self, **kwargs): def _chain(self):
""" """
Return a copy of the current QuerySet that's ready for another Return a copy of the current QuerySet that's ready for another
operation. operation.
@ -1331,7 +1331,6 @@ class QuerySet:
if obj._sticky_filter: if obj._sticky_filter:
obj.query.filter_is_sticky = True obj.query.filter_is_sticky = True
obj._sticky_filter = False obj._sticky_filter = False
obj.__dict__.update(kwargs)
return obj return obj
def _clone(self): def _clone(self):
@ -1622,11 +1621,11 @@ class Prefetch:
def __getstate__(self): def __getstate__(self):
obj_dict = self.__dict__.copy() obj_dict = self.__dict__.copy()
if self.queryset is not None: if self.queryset is not None:
queryset = self.queryset._chain()
# Prevent the QuerySet from being evaluated # Prevent the QuerySet from being evaluated
obj_dict['queryset'] = self.queryset._chain( queryset._result_cache = []
_result_cache=[], queryset._prefetch_done = True
_prefetch_done=True, obj_dict['queryset'] = queryset
)
return obj_dict return obj_dict
def add_prefix(self, prefix): def add_prefix(self, prefix):