Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nextcloud/server.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'lib/private/Files/Cache/Cache.php')
-rw-r--r--lib/private/Files/Cache/Cache.php22
1 files changed, 14 insertions, 8 deletions
diff --git a/lib/private/Files/Cache/Cache.php b/lib/private/Files/Cache/Cache.php
index aec97d1ad33..f471b5c7838 100644
--- a/lib/private/Files/Cache/Cache.php
+++ b/lib/private/Files/Cache/Cache.php
@@ -587,10 +587,13 @@ class Cache implements ICache {
return $cacheEntry->getId();
}, $children);
- $query = $this->getQueryBuilder();
- $query->delete('filecache_extended')
- ->where($query->expr()->in('fileid', $query->createNamedParameter($childIds, IQueryBuilder::PARAM_INT_ARRAY)));
- $query->execute();
+ $childIdChunks = array_chunk($childIds, 2048);
+ foreach ($childIdChunks as $childIdChunk) {
+ $query = $this->getQueryBuilder();
+ $query->delete('filecache_extended')
+ ->where($query->expr()->in('fileid', $query->createNamedParameter($childIdChunk, IQueryBuilder::PARAM_INT_ARRAY)));
+ $query->execute();
+ }
/** @var ICacheEntry[] $childFolders */
$childFolders = array_filter($children, function ($child) {
@@ -602,10 +605,13 @@ class Cache implements ICache {
}
}
- $query = $this->getQueryBuilder();
- $query->delete('filecache')
- ->whereParentIn($parentIds);
- $query->execute();
+ $parentIdChunks = array_chunk($parentIds, 2048);
+ foreach ($parentIdChunks as $parentIdChunk) {
+ $query = $this->getQueryBuilder();
+ $query->delete('filecache')
+ ->whereParentIn($parentIdChunk);
+ $query->execute();
+ }
}
/**