]> git.immae.eu Git - github/wallabag/wallabag.git/commitdiff
EntryRepository: refactor getBuilderForUntaggedByUser
authorKevin Decherf <kevin@kdecherf.com>
Sun, 2 Sep 2018 15:44:19 +0000 (17:44 +0200)
committerKevin Decherf <kevin@kdecherf.com>
Wed, 5 Sep 2018 16:44:08 +0000 (18:44 +0200)
Improve SQL performance by replacing size(e.tags) with a left join and a
null condition

Move the QueryBuilder logic into getRawBuilderForUntaggedByUser

Signed-off-by: Kevin Decherf <kevin@kdecherf.com>
src/Wallabag/CoreBundle/Repository/EntryRepository.php

index 749d2338c3b183314d7e9428546cb5f5c90e3d27..a31f97b5a5c95660f9b99f49764d5e4d0c105645 100644 (file)
@@ -102,7 +102,7 @@ class EntryRepository extends EntityRepository
     }
 
     /**
-     * Retrieves untagged entries for a user.
+     * Retrieve a sorted list of untagged entries for a user.
      *
      * @param int $userId
      *
@@ -111,8 +111,21 @@ class EntryRepository extends EntityRepository
     public function getBuilderForUntaggedByUser($userId)
     {
         return $this
-            ->getSortedQueryBuilderByUser($userId)
-            ->andWhere('size(e.tags) = 0');
+            ->sortQueryBuilder($this->getRawBuilderForUntaggedByUser($userId));
+    }
+
+    /**
+     * Retrieve untagged entries for a user.
+     * 
+     * @param int $userId
+     * 
+     * @return QueryBuilder
+     */
+    public function getRawBuilderForUntaggedByUser($userId)
+    {
+        return $this->getQueryBuilderByUser($userId)
+            ->leftJoin('e.tags', 't')
+            ->andWhere('t.id is null');
     }
 
     /**