我正在使用 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;
答案 0 :(得分:0)
查看您的代码,我发现您可以改进的一些内容如下所示。
例如:
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);
希望这有帮助!
干杯!