]> git.immae.eu Git - github/wallabag/wallabag.git/commitdiff
Add user_archived index
authorOlivier Mehani <shtrom@ssji.net>
Wed, 7 Aug 2019 11:44:00 +0000 (21:44 +1000)
committerOlivier Mehani <shtrom@ssji.net>
Wed, 7 Aug 2019 11:44:00 +0000 (21:44 +1000)
Signed-off-by: Olivier Mehani <shtrom@ssji.net>
app/DoctrineMigrations/Version20190806130304.php
src/Wallabag/CoreBundle/Entity/Entry.php

index 1449bdd3d8edcf98ba5df9020f9172076dff2b78..4d6b7897ad50e8ee6afbe14753e3b1a08b615ff8 100644 (file)
@@ -32,16 +32,19 @@ final class Version20190806130304 extends WallabagMigration
                 $this->addSql('CREATE INDEX IDX_F4D18282A76ED395 ON ' . $this->getTable('entry', true) . ' (user_id)');
                 $this->addSql('CREATE INDEX hashed_given_url_user_id ON ' . $this->getTable('entry', true) . ' (user_id, hashed_given_url)');
                 $this->addSql('CREATE INDEX user_language ON ' . $this->getTable('entry', true) . ' (language, user_id)');
+                $this->addSql('CREATE INDEX user_archived ON ' . $this->getTable('entry', true) . ' (user_id, is_archived, archived_at)');
                 $this->addSql('CREATE INDEX user_starred ON ' . $this->getTable('entry', true) . ' (user_id, is_starred, starred_at)');
                 break;
             case 'mysql':
                 $this->addSql('ALTER TABLE ' . $this->getTable('entry') . ' MODIFY language VARCHAR(20) DEFAULT NULL');
                 $this->addSql('CREATE INDEX user_language ON ' . $this->getTable('entry') . ' (language, user_id)');
+                $this->addSql('CREATE INDEX user_archived ON ' . $this->getTable('entry') . ' (user_id, is_archived, archived_at)');
                 $this->addSql('CREATE INDEX user_starred ON ' . $this->getTable('entry') . ' (user_id, is_starred, starred_at)');
                 break;
             case 'postgresql':
                 $this->addSql('ALTER TABLE ' . $this->getTable('entry') . ' ALTER language TYPE VARCHAR(20)');
                 $this->addSql('CREATE INDEX user_language ON ' . $this->getTable('entry') . ' (language, user_id)');
+                $this->addSql('CREATE INDEX user_archived ON ' . $this->getTable('entry') . ' (user_id, is_archived, archived_at)');
                 $this->addSql('CREATE INDEX user_starred ON ' . $this->getTable('entry') . ' (user_id, is_starred, starred_at)');
                 break;
         }
@@ -57,6 +60,7 @@ final class Version20190806130304 extends WallabagMigration
                 $this->addSql('DROP INDEX hashed_url_user_id');
                 $this->addSql('DROP INDEX hashed_given_url_user_id');
                 $this->addSql('DROP INDEX user_language');
+                $this->addSql('DROP INDEX user_archived');
                 $this->addSql('DROP INDEX user_starred');
                 $this->addSql('CREATE TEMPORARY TABLE __temp__wallabag_entry AS SELECT id, user_id, uid, title, url, hashed_url, origin_url, given_url, hashed_given_url, is_archived, archived_at, is_starred, content, created_at, updated_at, published_at, published_by, starred_at, mimetype, language, reading_time, domain_name, preview_picture, http_status, headers FROM ' . $this->getTable('entry', true));
                 $this->addSql('DROP TABLE ' . $this->getTable('entry', true));
@@ -74,11 +78,13 @@ final class Version20190806130304 extends WallabagMigration
             case 'mysql':
                 $this->addSql('ALTER TABLE ' . $this->getTable('entry') . ' MODIFY language LONGTEXT DEFAULT NULL');
                 $this->addSql('DROP INDEX user_language ON ' . $this->getTable('entry'));
+                $this->addSql('DROP INDEX user_archived ON ' . $this->getTable('entry'));
                 $this->addSql('DROP INDEX user_starred ON ' . $this->getTable('entry'));
                 break;
             case 'postgresql':
                 $this->addSql('ALTER TABLE ' . $this->getTable('entry') . ' ALTER language TYPE TEXT');
                 $this->addSql('DROP INDEX user_language ON ' . $this->getTable('entry'));
+                $this->addSql('DROP INDEX user_archived ON ' . $this->getTable('entry'));
                 $this->addSql('DROP INDEX user_starred ON ' . $this->getTable('entry'));
                 break;
         }
index 593ff01df8b22a606e9ee718e1176c769d0a76be..49f19cfa0db1f6da937ea4167f2b4761c4019169 100644 (file)
@@ -30,6 +30,7 @@ use Wallabag\UserBundle\Entity\User;
  *         @ORM\Index(name="hashed_url_user_id", columns={"user_id", "hashed_url"}, options={"lengths"={null, 40}}),
  *         @ORM\Index(name="hashed_given_url_user_id", columns={"user_id", "hashed_given_url"}, options={"lengths"={null, 40}}),
  *         @ORM\Index(name="user_language", columns={"language", "user_id"}),
+ *         @ORM\Index(name="user_archived", columns={"user_id", "is_archived", "archived_at"}),
  *         @ORM\Index(name="user_starred", columns={"user_id", "is_starred", "starred_at"})
  *     }
  * )