ZendFrameworkを学んでいます。Zend_Paginatorをアレイアダプタで動作させていましたが、Zend_Paginator::factory静的メソッドの使用に問題があります。問題は、ページネーション制御リンクが正しいURLに私を送信することですが、[次へ]または2、3ページなどをクリックすると、結果が表示されなくなります。
データベースから2つのテーブルがあります。ファイルテーブルとorigination_officeテーブルです。ファイルテーブルにはクライアントの名前、住所などがあり、発信元のオフィスにはオフィス名(タンパ、サラソタなど)が格納されています。各ファイルはオリジネーションオフィスに関連付けられています。
私のコントローラー:
public function searchAction()
{
$searchForm = new Application_Form_SearchForm();
if ($this->_request->getQuery()) {
if ($searchForm->isValid($this->_request->getParams())) {
$officeName = $this->_request->getParam('officeName');
$page = $this->_request->getParam('page');
}
$fileTable = new Application_Model_DbTable_File();
$this->view->paginator = $fileTable->getFilesByOfficeName($officeName, $page);
}
$this->view->searchForm = $searchForm;
}
getFilesByOfficeName()メソッドは次のとおりです。
public function getFilesByOfficeName($officeName = null, $page = 1, $count = 12, $range = 15, $scrolling = 'Sliding')
{
if (is_null($officeName)) {
$query = $this->select();
$paginator = Zend_Paginator::factory($query);
} else {
$oofTable = new Application_Model_DbTable_OriginationOffice();
$query = $oofTable->select();
$query->where('oof_name like ?', $officeName.'%');
if ($oofTable->fetchRow($query)) {
$origination_office = $oofTable->fetchRow($query);
$files = $origination_office->findDependentRowset($this);
$paginator = Zend_Paginator::factory($files);
} else {
return;
}
}
Zend_Paginator::setDefaultScrollingStyle($scrolling);
Zend_View_Helper_PaginationControl::setDefaultViewPartial('_pagination_control.phtml');
$paginator->setDefaultItemCountPerPage($count);
$paginator->setDefaultPageRange($range);
$paginator->setCurrentPageNumber($page);
return $paginator;
}