diff options
author | Thomas Citharel <tcit@tcit.fr> | 2019-10-07 14:39:27 +0200 |
---|---|---|
committer | Thomas Citharel <tcit@tcit.fr> | 2019-10-08 10:25:56 +0200 |
commit | 68cf47e947b06eb22a22c460e0febc796e5609e2 (patch) | |
tree | b42e3961611cb536a6d31afa68456a932b3a3978 | |
parent | b7803665c1c030378511161dd51c10ac17e6cf6b (diff) | |
download | nextcloud-server-68cf47e947b06eb22a22c460e0febc796e5609e2.tar.gz nextcloud-server-68cf47e947b06eb22a22c460e0febc796e5609e2.zip |
Check and add index on principaluri for schedulingobjects table
Signed-off-by: Thomas Citharel <tcit@tcit.fr>
-rw-r--r-- | core/Application.php | 7 | ||||
-rw-r--r-- | core/Command/Db/AddMissingIndices.php | 13 |
2 files changed, 20 insertions, 0 deletions
diff --git a/core/Application.php b/core/Application.php index 659a2c5d3d9..cc4d9ba990b 100644 --- a/core/Application.php +++ b/core/Application.php @@ -153,6 +153,13 @@ class Application extends App { $subject->addHintForMissingSubject($table->getName(), 'calendarobject_calid_index'); } } + + if ($schema->hasTable('schedulingobjects')) { + $table = $schema->getTable('schedulingobjects'); + if (!$table->hasIndex('schedulobj_principuri_index')) { + $subject->addHintForMissingSubject($table->getName(), 'schedulobj_principuri_index'); + } + } } ); diff --git a/core/Command/Db/AddMissingIndices.php b/core/Command/Db/AddMissingIndices.php index 02c89992105..527a2cd7b19 100644 --- a/core/Command/Db/AddMissingIndices.php +++ b/core/Command/Db/AddMissingIndices.php @@ -234,6 +234,19 @@ class AddMissingIndices extends Command { } } + $output->writeln('<info>Check indices of the schedulingobjects table.</info>'); + if ($schema->hasTable('schedulingobjects')) { + $table = $schema->getTable('schedulingobjects'); + if (!$table->hasIndex('schedulobj_principuri_index')) { + $output->writeln('<info>Adding schedulobj_principuri_index index to the schedulingobjects table, this can take some time...</info>'); + + $table->addIndex(['principaluri'], 'schedulobj_principuri_index'); + $this->connection->migrateToSchema($schema->getWrappedSchema()); + $updated = true; + $output->writeln('<info>schedulingobjects table updated successfully.</info>'); + } + } + if (!$updated) { $output->writeln('<info>Done.</info>'); } |