summaryrefslogtreecommitdiffstats
path: root/core/Command
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2021-10-07 16:11:49 +0200
committerRobin Appelman <robin@icewind.nl>2021-10-07 16:11:49 +0200
commit6502dfae343850f510471b72ebece1c1329343e0 (patch)
treed36400494c758c5862271c43ff2507b4b6614c25 /core/Command
parent682944925839e5300c02a231b261bb6fc6dfdf20 (diff)
downloadnextcloud-server-6502dfae343850f510471b72ebece1c1329343e0.tar.gz
nextcloud-server-6502dfae343850f510471b72ebece1c1329343e0.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/Command')
-rw-r--r--core/Command/Db/AddMissingIndices.php7
1 files changed, 7 insertions, 0 deletions
diff --git a/core/Command/Db/AddMissingIndices.php b/core/Command/Db/AddMissingIndices.php
index 2e6b3dc9aeb..c4360157f72 100644
--- a/core/Command/Db/AddMissingIndices.php
+++ b/core/Command/Db/AddMissingIndices.php
@@ -144,6 +144,13 @@ class AddMissingIndices extends Command {
$updated = true;
$output->writeln('<info>Filecache table updated successfully.</info>');
}
+ if (!$table->hasIndex('fs_id_storage_size')) {
+ $output->writeln('<info>Adding additional size index to the filecache table, this can take some time...</info>');
+ $table->addIndex(['fileid', 'storage', 'size'], 'fs_id_storage_size');
+ $this->connection->migrateToSchema($schema->getWrappedSchema());
+ $updated = true;
+ $output->writeln('<info>Filecache table updated successfully.</info>');
+ }
}
$output->writeln('<info>Check indices of the twofactor_providers table.</info>');