diff --git a/lib/private/Files/Cache/Cache.php b/lib/private/Files/Cache/Cache.php index cd88aebb17dfc..1b79e5a648e92 100644 --- a/lib/private/Files/Cache/Cache.php +++ b/lib/private/Files/Cache/Cache.php @@ -623,6 +623,9 @@ private function removeChildren(ICacheEntry $entry) { $query->delete('filecache') ->whereParentInParameter('parentIds'); + // Sorting before chunking allows the db to find the entries close to each + // other in the index + sort($parentIds, SORT_NUMERIC); foreach (array_chunk($parentIds, 1000) as $parentIdChunk) { $query->setParameter('parentIds', $parentIdChunk, IQueryBuilder::PARAM_INT_ARRAY); $query->execute();