diff options
author | Robin Appelman <robin@icewind.nl> | 2021-10-07 16:11:49 +0200 |
---|---|---|
committer | Robin Appelman <robin@icewind.nl> | 2022-01-13 15:48:14 +0100 |
commit | 3a1935b7ff25ace59a1af739b80fac51b0aa7cdd (patch) | |
tree | 653d026f67f3bd5bdf0206060664f071eadb604d /core/Migrations/Version13000Date20170718121200.php | |
parent | 09c350c57621d73fd9d8b73bec9f2a00328ae92c (diff) | |
download | nextcloud-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/Migrations/Version13000Date20170718121200.php')
-rw-r--r-- | core/Migrations/Version13000Date20170718121200.php | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/core/Migrations/Version13000Date20170718121200.php b/core/Migrations/Version13000Date20170718121200.php index 393fe4f6ad6..013ce26b217 100644 --- a/core/Migrations/Version13000Date20170718121200.php +++ b/core/Migrations/Version13000Date20170718121200.php @@ -261,6 +261,7 @@ class Version13000Date20170718121200 extends SimpleMigrationStep { $table->addIndex(['storage', 'mimetype'], 'fs_storage_mimetype'); $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(['mtime'], 'fs_mtime'); $table->addIndex(['size'], 'fs_size'); if (!$schema->getDatabasePlatform() instanceof PostgreSQL94Platform) { |