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