More straightforward next/prev post calculation

Instead of getting all three rows at once using abs(id1-id2)<=1, it now asks DB
explicitly about id-1 and id+1. Even though it uses more SQL queries, it's
actually slightly faster.
This commit is contained in:
Marcin Kurczewski 2014-02-23 10:03:05 +01:00
parent a4fadb218b
commit 4ce4ea6f70

View file

@ -23,38 +23,26 @@ class PostSearchService extends AbstractSearchService
Database::exec($stmt); Database::exec($stmt);
$stmt = new SqlSelectStatement(); $stmt = new SqlSelectStatement();
$stmt->setColumn('post_id');
$stmt->setTable('post_search'); $stmt->setTable('post_search');
$stmt->setCriterion( $stmt->setColumn('id');
new SqlEqualsOrLesserOperator( $stmt->setCriterion(new SqlEqualsOperator('post_id', new SqlBinding($postId)));
new SqlAbsOperator( $rowId = Database::fetchOne($stmt)['id'];
new SqlSubtractionOperator('id', (new SqlSelectStatement)
->setTable('post_search')
->setColumn('id')
->setCriterion(new SqlEqualsOperator('post_id', new SqlBinding($postId))))),
1));
$rows = Database::fetchAll($stmt);
$ids = array_map(function($row) { return $row['post_id']; }, $rows);
if (count($ids) == 1 or // no prev and no next post //it's possible that given post won't show in search results:
count($ids) == 0) // even the post we are looking at is hidden from normal search for whatever reason //it can be hidden, it can have prohibited safety etc.
{ if (!$rowId)
return [null, null]; return [null, null];
}
elseif (count($ids) == 2) // no prev or no next post $rowId = intval($rowId);
{ $stmt->setColumn('post_id');
return $ids[0] == $postId
? [$ids[1], null] $stmt->setCriterion(new SqlEqualsOperator('id', new SqlBinding($rowId - 1)));
: [null, $ids[0]]; $nextPostId = Database::fetchOne($stmt)['post_id'];
}
elseif (count($ids) == 3) // both prev and next post $stmt->setCriterion(new SqlEqualsOperator('id', new SqlBinding($rowId + 1)));
{ $prevPostId = Database::fetchOne($stmt)['post_id'];
return [$ids[2], $ids[0]];
} return [$prevPostId, $nextPostId];
else
{
throw new Exception('Unexpected result count (ids: ' . join(',', $ids) . ')');
}
}); });
} }