summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2023-06-08 17:14:18 +0200
committerbackportbot-nextcloud[bot] <backportbot-nextcloud[bot]@users.noreply.github.com>2023-08-14 18:58:47 +0000
commita5cd892caa42f66cfaea0089b6b7bc0e04327a3a (patch)
treeb282b57eed2cc7ab82c69846381457ef5f67c9d0 /lib
parent76efab3c7c83e950e8b12455a23e70df70d9339a (diff)
downloadnextcloud-server-a5cd892caa42f66cfaea0089b6b7bc0e04327a3a.tar.gz
nextcloud-server-a5cd892caa42f66cfaea0089b6b7bc0e04327a3a.zip
select the fileid first when looking for incomplete files
this seems to improve mariadbs index selection Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'lib')
-rw-r--r--lib/private/Files/Cache/Cache.php14
1 files changed, 9 insertions, 5 deletions
diff --git a/lib/private/Files/Cache/Cache.php b/lib/private/Files/Cache/Cache.php
index 1adc14c626c..76b2fa942cc 100644
--- a/lib/private/Files/Cache/Cache.php
+++ b/lib/private/Files/Cache/Cache.php
@@ -1025,8 +1025,12 @@ class Cache implements ICache {
* @return string|false the path of the folder or false when no folder matched
*/
public function getIncomplete() {
+ // we select the fileid here first instead of directly selecting the path since this helps mariadb/mysql
+ // to use the correct index.
+ // The overhead of this should be minimal since the cost of selecting the path by id should be much lower
+ // than the cost of finding an item with size < 0
$query = $this->getQueryBuilder();
- $query->select('path')
+ $query->select('fileid')
->from('filecache')
->whereStorageId($this->getNumericStorageId())
->andWhere($query->expr()->lt('size', $query->createNamedParameter(0, IQueryBuilder::PARAM_INT)))
@@ -1034,15 +1038,15 @@ class Cache implements ICache {
->setMaxResults(1);
$result = $query->execute();
- $path = $result->fetchOne();
+ $id = $result->fetchOne();
$result->closeCursor();
- if ($path === false) {
+ if ($id === false) {
return false;
}
- // Make sure Oracle does not continue with null for empty strings
- return (string)$path;
+ $path = $this->getPathById($id);
+ return $path ?? false;
}
/**