Further tweaks to model

- Fixed broken negative searches
- Faster search by tag / comment / submit / favorites (useless nested joins
  replaced to entity prefetch). Side effect: searching for nonexistent tags,
  users etc yields informative errors instead of "no posts to show")
- Fixed duplicated column in order clause ("ORDER BY id DESC, id DESC")
This commit is contained in:
Marcin Kurczewski 2013-11-30 19:07:39 +01:00
parent 992b9ba5ac
commit 0001d38699
2 changed files with 29 additions and 33 deletions

View file

@ -33,16 +33,20 @@ abstract class AbstractModel extends RedBean_SimpleModel
protected static function convertRows($rows, $table, $fast = false) protected static function convertRows($rows, $table, $fast = false)
{ {
if (empty($rows))
return [];
if (!$fast) if (!$fast)
return R::convertToBeans($table, $rows); return R::convertToBeans($table, $rows);
$entities = R::dispense($table, count($rows)); $entities = R::dispense($table, count($rows));
reset($entities); if (count($rows) == 1)
$entities = [$entities];
$entity = reset($entities);
foreach ($rows as $row) foreach ($rows as $row)
{ {
$entity = current($entities);
$entity->import($row); $entity->import($row);
next($entities); $entity = next($entities);
} }
reset($entities); reset($entities);
return $entities; return $entities;

View file

@ -40,15 +40,14 @@ class Model_Post_QueryBuilder implements AbstractQueryBuilder
protected static function filterTag($dbQuery, $val) protected static function filterTag($dbQuery, $val)
{ {
$tag = Model_Tag::locate($val);
$dbQuery $dbQuery
->exists() ->exists()
->open() ->open()
->select('1') ->select('1')
->from('post_tag') ->from('post_tag')
->innerJoin('tag')
->on('post_tag.tag_id = tag.id')
->where('post_id = post.id') ->where('post_id = post.id')
->and('LOWER(tag.name) = LOWER(?)')->put($val) ->and('post_tag.tag_id = ?')->put($tag->id)
->close(); ->close();
} }
@ -187,9 +186,8 @@ class Model_Post_QueryBuilder implements AbstractQueryBuilder
{ {
list ($timeMin, $timeMax) = self::__filterTokenDateParser($val); list ($timeMin, $timeMax) = self::__filterTokenDateParser($val);
$dbQuery $dbQuery
->addSql('upload_date >= ?')->and('upload_date <= ?') ->addSql('upload_date >= ?')->put($timeMin)
->put($timeMin) ->and('upload_date <= ?')->put($timeMax);
->put($timeMax);
} }
protected static function filterTokenDateMin($context, $dbQuery, $val) protected static function filterTokenDateMin($context, $dbQuery, $val)
@ -206,15 +204,14 @@ class Model_Post_QueryBuilder implements AbstractQueryBuilder
protected static function filterTokenFav($context, $dbQuery, $val) protected static function filterTokenFav($context, $dbQuery, $val)
{ {
$user = Model_User::locate($val);
$dbQuery $dbQuery
->exists() ->exists()
->open() ->open()
->select('1') ->select('1')
->from('favoritee') ->from('favoritee')
->innerJoin('user')
->on('favoritee.user_id = user.id')
->where('post_id = post.id') ->where('post_id = post.id')
->and('LOWER(user.name) = LOWER(?)')->put($val) ->and('favoritee.user_id = ?')->put($user->id)
->close(); ->close();
} }
@ -225,15 +222,14 @@ class Model_Post_QueryBuilder implements AbstractQueryBuilder
protected static function filterTokenComment($context, $dbQuery, $val) protected static function filterTokenComment($context, $dbQuery, $val)
{ {
$user = Model_User::locate($val);
$dbQuery $dbQuery
->exists() ->exists()
->open() ->open()
->select('1') ->select('1')
->from('comment') ->from('comment')
->innerJoin('user')
->on('commenter_id = user.id')
->where('post_id = post.id') ->where('post_id = post.id')
->and('LOWER(user.name) = LOWER(?)')->put($val) ->and('commenter_id = ?')->put($user->id)
->close(); ->close();
} }
@ -244,13 +240,8 @@ class Model_Post_QueryBuilder implements AbstractQueryBuilder
protected static function filterTokenSubmit($context, $dbQuery, $val) protected static function filterTokenSubmit($context, $dbQuery, $val)
{ {
$dbQuery $user = Model_User::locate($val);
->addSql('uploader_id = ') $dbQuery->addSql('uploader_id = ?')->put($user->id);
->open()
->select('user.id')
->from('user')
->where('LOWER(name) = LOWER(?)')->put($val)
->close();
} }
protected static function filterTokenUploader($context, $dbQuery, $val) protected static function filterTokenUploader($context, $dbQuery, $val)
@ -384,17 +375,15 @@ class Model_Post_QueryBuilder implements AbstractQueryBuilder
{ {
$unparsedTokens = []; $unparsedTokens = [];
foreach ($tokens as $token) foreach ($tokens as $origToken)
{ {
$token = $origToken;
$neg = false;
if ($token{0} == '-') if ($token{0} == '-')
{ {
$token = substr($token, 1); $token = substr($token, 1);
$neg = true; $neg = true;
} }
else
{
$neg = false;
}
$pos = strpos($token, ':'); $pos = strpos($token, ':');
if ($pos === false) if ($pos === false)
@ -411,7 +400,7 @@ class Model_Post_QueryBuilder implements AbstractQueryBuilder
$parsed = $callback($neg, $key, $val); $parsed = $callback($neg, $key, $val);
if (!$parsed) if (!$parsed)
$unparsedTokens []= $token; $unparsedTokens []= $origToken;
} }
return $unparsedTokens; return $unparsedTokens;
} }
@ -485,10 +474,13 @@ class Model_Post_QueryBuilder implements AbstractQueryBuilder
else else
$dbQuery->asc(); $dbQuery->asc();
$dbQuery->addSql(', id '); if ($context->orderColumn != 'id')
if ($context->orderDir == 1) {
$dbQuery->desc(); $dbQuery->addSql(', id');
else if ($context->orderDir == 1)
$dbQuery->asc(); $dbQuery->desc();
else
$dbQuery->asc();
}
} }
} }