From 407ff41bbc01fdfb7a45093a2b71b64ae5e9f8b1 Mon Sep 17 00:00:00 2001 From: Louis Chemineau Date: Wed, 15 Feb 2023 15:57:44 +0100 Subject: [PATCH] Add parent index on filecache Signed-off-by: Louis Chemineau --- core/Application.php | 4 ++++ core/Command/Db/AddMissingIndices.php | 10 ++++++++++ core/Migrations/Version13000Date20170718121200.php | 1 + 3 files changed, 15 insertions(+) diff --git a/core/Application.php b/core/Application.php index 6b3d7d6e0c71b..4ebbada95e666 100644 --- a/core/Application.php +++ b/core/Application.php @@ -132,6 +132,10 @@ function (GenericEvent $event) use ($container) { if (!$table->hasIndex('fs_storage_path_prefix') && !$schema->getDatabasePlatform() instanceof PostgreSQL94Platform) { $subject->addHintForMissingSubject($table->getName(), 'fs_storage_path_prefix'); } + + if (!$table->hasIndex('fs_parent')) { + $subject->addHintForMissingSubject($table->getName(), 'fs_parent'); + } } if ($schema->hasTable('twofactor_providers')) { diff --git a/core/Command/Db/AddMissingIndices.php b/core/Command/Db/AddMissingIndices.php index 5799a462ffa38..e22d0fddeca34 100644 --- a/core/Command/Db/AddMissingIndices.php +++ b/core/Command/Db/AddMissingIndices.php @@ -182,6 +182,16 @@ private function addCoreIndexes(OutputInterface $output, bool $dryRun): void { $updated = true; $output->writeln('Filecache table updated successfully.'); } + if (!$table->hasIndex('fs_parent')) { + $output->writeln('Adding additional parent index to the filecache table, this can take some time...'); + $table->addIndex(['parent'], 'fs_parent'); + $sqlQueries = $this->connection->migrateToSchema($schema->getWrappedSchema(), $dryRun); + if ($dryRun && $sqlQueries !== null) { + $output->writeln($sqlQueries); + } + $updated = true; + $output->writeln('Filecache table updated successfully.'); + } } $output->writeln('Check indices of the twofactor_providers table.'); diff --git a/core/Migrations/Version13000Date20170718121200.php b/core/Migrations/Version13000Date20170718121200.php index 5439998fce303..0924e0590d364 100644 --- a/core/Migrations/Version13000Date20170718121200.php +++ b/core/Migrations/Version13000Date20170718121200.php @@ -262,6 +262,7 @@ public function changeSchema(IOutput $output, \Closure $schemaClosure, array $op $table->addIndex(['storage', 'mimepart'], 'fs_storage_mimepart'); $table->addIndex(['storage', 'size', 'fileid'], 'fs_storage_size'); $table->addIndex(['fileid', 'storage', 'size'], 'fs_id_storage_size'); + $table->addIndex(['parent'], 'fs_parent'); $table->addIndex(['mtime'], 'fs_mtime'); $table->addIndex(['size'], 'fs_size'); if (!$schema->getDatabasePlatform() instanceof PostgreSQL94Platform) {