From f9528f81834a96dda72523f357219d7d3853422c Mon Sep 17 00:00:00 2001 From: Marcin Kurczewski Date: Thu, 6 Nov 2014 20:00:52 +0100 Subject: [PATCH] Switched to subqueries from manual fetching --- src/Dao/PostDao.php | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) diff --git a/src/Dao/PostDao.php b/src/Dao/PostDao.php index 8c4bd72f..dc9dc276 100644 --- a/src/Dao/PostDao.php +++ b/src/Dao/PostDao.php @@ -138,11 +138,13 @@ class PostDao extends AbstractDao implements ICrudDao { foreach ($requirement->getValue()->getValues() as $userName) { - $userId = $this->userDao->findByName($userName)->getId(); - $sql = 'EXISTS (SELECT 1 FROM favorites f WHERE f.postId = posts.id AND f.userId = ?)'; + $sql = 'EXISTS ( + SELECT 1 FROM favorites f + WHERE f.postId = posts.id + AND f.userId = (SELECT id FROM users WHERE name = ?))'; if ($requirement->isNegated()) $sql = 'NOT ' . $sql; - $query->where($sql, [$userId]); + $query->where($sql, [$userName]); } return; } @@ -151,11 +153,13 @@ class PostDao extends AbstractDao implements ICrudDao { foreach ($requirement->getValue()->getValues() as $userName) { - $userId = $this->userDao->findByName($userName)->getId(); - $sql = 'EXISTS (SELECT 1 FROM comments c WHERE c.postId = posts.id AND c.userId = ?)'; + $sql = 'EXISTS ( + SELECT 1 FROM comments c + WHERE c.postId = posts.id + AND c.userId = (SELECT id FROM users WHERE name = ?))'; if ($requirement->isNegated()) $sql = 'NOT ' . $sql; - $query->where($sql, [$userId]); + $query->where($sql, [$userName]); } return; } @@ -170,15 +174,14 @@ class PostDao extends AbstractDao implements ICrudDao $values = $requirement->getValue()->getValues(); $userName = $values[0]; $score = $values[1]; - $userId = $this->userDao->findByName($userName)->getId(); $sql = 'EXISTS ( SELECT 1 FROM scores WHERE scores.postId = posts.id - AND scores.userId = ? + AND scores.userId = (SELECT id FROM users WHERE name = ?) AND scores.score = ?)'; if ($requirement->isNegated()) $sql = 'NOT ' . $sql; - $query->where($sql, [$userId, $score]); + $query->where($sql, [$userName, $score]); return; }