我正在使用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;

最佳答案

查看您的代码,我发现您可以改进以下几点。


不要使用“ 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);


希望这可以帮助!

干杯!

关于mysql - Zend分页器运行非常慢1.12,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/26708731/

10-16 14:49