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:
parent
992b9ba5ac
commit
0001d38699
2 changed files with 29 additions and 33 deletions
|
@ -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;
|
||||||
|
|
|
@ -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();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue