Optimization: preloading moved back to controllers

- Nearly twice faster page load
- Query count greatly dropped
This commit is contained in:
Marcin Kurczewski 2013-11-30 00:53:09 +01:00
parent 5a231b19c3
commit c9a8f99f6a
7 changed files with 18 additions and 28 deletions

View file

@ -24,6 +24,7 @@ class CommentController
$pageCount = ceil($commentCount / $commentsPerPage); $pageCount = ceil($commentCount / $commentsPerPage);
$page = max(1, min($pageCount, $page)); $page = max(1, min($pageCount, $page));
$comments = Model_Comment::getEntities(null, $commentsPerPage, $page); $comments = Model_Comment::getEntities(null, $commentsPerPage, $page);
R::preload($comments, ['commenter' => 'user', 'post', 'post.uploader' => 'user', 'post.sharedTag']);
$this->context->postGroups = true; $this->context->postGroups = true;
$this->context->transport->paginator = new StdClass; $this->context->transport->paginator = new StdClass;
@ -79,6 +80,8 @@ class CommentController
public function deleteAction($id) public function deleteAction($id)
{ {
$comment = Model_Comment::locate($id); $comment = Model_Comment::locate($id);
R::preload($comment, ['commenter' => 'user']);
PrivilegesHelper::confirmWithException(Privilege::DeleteComment, PrivilegesHelper::getIdentitySubPrivilege($comment->commenter)); PrivilegesHelper::confirmWithException(Privilege::DeleteComment, PrivilegesHelper::getIdentitySubPrivilege($comment->commenter));
Model_Comment::remove($comment); Model_Comment::remove($comment);

View file

@ -107,6 +107,7 @@ class PostController
$pageCount = ceil($postCount / $postsPerPage); $pageCount = ceil($postCount / $postsPerPage);
$page = max(1, min($pageCount, $page)); $page = max(1, min($pageCount, $page));
$posts = Model_Post::getEntitiesFast($query, $postsPerPage, $page); $posts = Model_Post::getEntitiesFast($query, $postsPerPage, $page);
R::preload($posts, 'sharedTag');
$this->context->transport->paginator = new StdClass; $this->context->transport->paginator = new StdClass;
$this->context->transport->paginator->page = $page; $this->context->transport->paginator->page = $page;
@ -299,6 +300,8 @@ class PostController
public function hideAction($id) public function hideAction($id)
{ {
$post = Model_Post::locate($id); $post = Model_Post::locate($id);
R::preload($post, ['uploader' => 'user']);
PrivilegesHelper::confirmWithException(Privilege::HidePost, PrivilegesHelper::getIdentitySubPrivilege($post->uploader)); PrivilegesHelper::confirmWithException(Privilege::HidePost, PrivilegesHelper::getIdentitySubPrivilege($post->uploader));
if (InputHelper::get('submit')) if (InputHelper::get('submit'))
@ -319,6 +322,8 @@ class PostController
public function unhideAction($id) public function unhideAction($id)
{ {
$post = Model_Post::locate($id); $post = Model_Post::locate($id);
R::preload($post, ['uploader' => 'user']);
PrivilegesHelper::confirmWithException(Privilege::HidePost, PrivilegesHelper::getIdentitySubPrivilege($post->uploader)); PrivilegesHelper::confirmWithException(Privilege::HidePost, PrivilegesHelper::getIdentitySubPrivilege($post->uploader));
if (InputHelper::get('submit')) if (InputHelper::get('submit'))
@ -339,6 +344,8 @@ class PostController
public function deleteAction($id) public function deleteAction($id)
{ {
$post = Model_Post::locate($id); $post = Model_Post::locate($id);
R::preload($post, ['uploader' => 'user']);
PrivilegesHelper::confirmWithException(Privilege::DeletePost, PrivilegesHelper::getIdentitySubPrivilege($post->uploader)); PrivilegesHelper::confirmWithException(Privilege::DeletePost, PrivilegesHelper::getIdentitySubPrivilege($post->uploader));
if (InputHelper::get('submit')) if (InputHelper::get('submit'))
@ -441,8 +448,9 @@ class PostController
$post = Model_Post::locate($id); $post = Model_Post::locate($id);
R::preload($post, [ R::preload($post, [
'tag', 'tag',
'comment', 'uploader' => 'user',
'ownComment.commenter' => 'user']); 'ownComment.commenter' => 'user']);
R::preload($this->context->user, ['ownFavoritee']);
$this->context->transport->lastSearchQuery = InputHelper::get('last-search-query'); $this->context->transport->lastSearchQuery = InputHelper::get('last-search-query');
@ -552,6 +560,9 @@ class PostController
private function doEdit($post, $isNew) private function doEdit($post, $isNew)
{ {
if (!$isNew)
R::preload($post, ['uploader' => 'user']);
/* file contents */ /* file contents */
if (!empty($_FILES['file']['name'])) if (!empty($_FILES['file']['name']))
{ {

View file

@ -441,6 +441,7 @@ class UserController
$pageCount = ceil($postCount / $postsPerPage); $pageCount = ceil($postCount / $postsPerPage);
$page = max(1, min($pageCount, $page)); $page = max(1, min($pageCount, $page));
$posts = Model_Post::getEntities($query, $postsPerPage, $page); $posts = Model_Post::getEntities($query, $postsPerPage, $page);
R::preload($posts, 'sharedTag');
$this->context->transport->tab = $tab; $this->context->transport->tab = $tab;
$this->context->transport->lastSearchQuery = $query; $this->context->transport->lastSearchQuery = $query;

View file

@ -81,19 +81,4 @@ abstract class AbstractModel extends RedBean_SimpleModel
{ {
R::store($entity); R::store($entity);
} }
/* FUSE methods for RedBeanPHP, preventing some aliasing errors */
public function open()
{
$this->preload();
}
public function after_update()
{
$this->preload();
}
public function preload()
{
}
} }

View file

@ -11,11 +11,6 @@ class Model_Comment extends AbstractModel
return 'Model_Comment_QueryBuilder'; return 'Model_Comment_QueryBuilder';
} }
public function preload()
{
R::preload($this->bean, ['commenter' => 'user', 'post', 'post.uploader' => 'user']);
}
public static function locate($key, $throw = true) public static function locate($key, $throw = true)

View file

@ -18,11 +18,6 @@ class Model_Post extends AbstractModel
return 'Model_Post_QueryBuilder'; return 'Model_Post_QueryBuilder';
} }
public function preload()
{
R::preload($this->bean, ['uploader' => 'user','favoritee' => 'user']);
}
public static function locate($key, $disallowNumeric = false, $throw = true) public static function locate($key, $disallowNumeric = false, $throw = true)

View file

@ -24,8 +24,8 @@
$x = $x =
[ [
'score' => $this->context->post->score, 'score' => $this->context->post->score,
'comments' => $this->context->post->countOwn('comment'), 'comments' => $this->context->post->comment_count,
'favs' => $this->context->post->countOwn('favoritee'), 'favs' => $this->context->post->fav_count,
]; ];
?> ?>
<?php if (!empty($x)): ?> <?php if (!empty($x)): ?>