summaryrefslogtreecommitdiffstats
path: root/core/Application.php
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2021-10-07 16:11:49 +0200
committerRobin Appelman <robin@icewind.nl>2022-01-13 15:48:14 +0100
commit3a1935b7ff25ace59a1af739b80fac51b0aa7cdd (patch)
tree653d026f67f3bd5bdf0206060664f071eadb604d /core/Application.php
parent09c350c57621d73fd9d8b73bec9f2a00328ae92c (diff)
downloadnextcloud-server-3a1935b7ff25ace59a1af739b80fac51b0aa7cdd.tar.gz
nextcloud-server-3a1935b7ff25ace59a1af739b80fac51b0aa7cdd.zip
add better index for finding unindexed paths
for the following query 'SELECT "path" FROM "oc_filecache" WHERE ("storage" = $storage) AND ("size" < 0) ORDER BY "fileid" DESC LIMIT 1;' currently the database will in some cases decide to priorize the sort by fileid over the filter when picking what index to use, resulting in a much slower query. by creating an index that allows first sorting by fileid and also filter by storage and size this case will be greatly sped up Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'core/Application.php')
-rw-r--r--core/Application.php4
1 files changed, 4 insertions, 0 deletions
diff --git a/core/Application.php b/core/Application.php
index c127d94622f..7a4fe491db3 100644
--- a/core/Application.php
+++ b/core/Application.php
@@ -120,6 +120,10 @@ class Application extends App {
if (!$table->hasIndex('fs_storage_path_prefix') && !$schema->getDatabasePlatform() instanceof PostgreSQL94Platform) {
$subject->addHintForMissingSubject($table->getName(), 'fs_storage_path_prefix');
}
+
+ if (!$table->hasIndex('fs_id_storage_size')) {
+ $subject->addHintForMissingSubject($table->getName(), 'fs_id_storage_size');
+ }
}
if ($schema->hasTable('twofactor_providers')) {