From b226039fe9c6aab8950165923ffba9d75fafaa74 Mon Sep 17 00:00:00 2001 From: Christoph Wurst Date: Fri, 26 Apr 2024 15:38:29 +0200 Subject: perf(db): Sort data for IN before chunking Signed-off-by: Christoph Wurst --- lib/private/Files/Cache/Cache.php | 3 +++ 1 file changed, 3 insertions(+) (limited to 'lib') diff --git a/lib/private/Files/Cache/Cache.php b/lib/private/Files/Cache/Cache.php index 5a3e38dd569..9822b6874f9 100644 --- a/lib/private/Files/Cache/Cache.php +++ b/lib/private/Files/Cache/Cache.php @@ -629,6 +629,9 @@ class Cache implements ICache { $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(); -- cgit v1.2.3