Zend paginator运行速度非常慢1.12

时间:2014-11-03 06:10:35

标签: mysql zend-framework zend-db-table zend-db-select zend-paginator

我正在使用 zend paginator 来获取记录并列出相同的记录。

四个联接,我已经索引了所有相应的字段,我只获得了所有表中列出的必填字段。记录总数可能 500万。我试图优化最大值和最后我发现下面的代码是最好的。

$select = new Zend_Paginator_Adapter_DbSelect($select);
$select->count($select);
$paginator = new Zend_Paginator($select);

但即使这样,加载页面也需要 40秒。有人可以帮助我获得更好的表现。

我对我的问题几乎没有更新。下面是我的代码

$query = $this->select();
$query->setIntegrityCheck(false);

$query->from(array('test1' => '*')))
->join(array('test2' => 'test2'), 'test2.id = test1.test2_id', array('*'))
->joinLeft(array('test3' => 'test3'), ("test1.test2_id = test3.test2_id'"), array('*')
->joinLeft(array('test4' => 'test4'), "test1.test4_id = test4.test4_id", array('*'))
->join(array('test5' => 'test5'), 'test1.test5_id = test5.id', array('*'));

$paginator = new Zend_Paginator(new Zend_Paginator_Adapter_DbTableSelect($query));

$paginator->setItemCountPerPage(ITEM_PER_PAGE);
$paginator->setCurrentPageNumber($this->getRequest()->getParam('page', 1));
$paginator->setPageRange(PAGE_RANGE);

$this->view->paginator = $paginator;

1 个答案:

答案 0 :(得分:0)

查看您的代码,我发现您可以改进的一些内容如下所示。

  • 不要使用" SELECT * FROM",只选择您需要的字段。
  • 查看速度比原始查询快得多。
  • 解释查询以检查执行时间等。

例如:

CREATE VIEW USER_DATA_VIEW AS
SELECT 
T1.column1,T1.column2,T1.column3
T2.column1,T2.column2,T3.column1
T3.column2,T4.column1,T5.column1 
....
FROM test1 as T1
JOIN test2 as T2 T2.id = T1.test2_id
LEFT JOIN test3 as T3 T3.id = T1.test3_id
JOIN test4 as T4 T4.id = T3.test3_id
JOIN test5 as T5 T5.id = T5.test4_id

现在使用VIEW检索数据。

SELECT column(s) FROM USER_DATA_VIEW 

如下所示从VIEW检索数据,使用LIMIT子句也是另一个最佳选择。

$modelObject = new Your_Model_View;

$select = $this->select();
$modelObject->fetchAll($select);

希望这有帮助!

干杯!