База данных компонентов Zend Framework не может найти класс Zend_Paginator_Adapter_DbTableSelect

Я использую некоторые библиотеки Zend вне Zend Framework в небольшом проекте. Я использую Zend_Db и Zend_Paginator, но когда я пытаюсь настроить разбиение на страницы с помощью Zend_Paginator_Adapter_DbTableSelect, я получаю сообщение об ошибке, что он не может найти класс.

Неустранимая ошибка: класс Zend_Paginator_Adapter_DbTableSelect не найден в C:\xampp\htdocs\php_testing\zend\zend_db\index1.php в строке 65 Вот мой код:

<?
require_once 'Zend/Db.php';
$config=array(
    'adapter' => 'PDO_MYSQL',
    'hostname' => 'localhost',
    'dbname' => 'dm_xxxx',
    'username' => 'un',
    'password' => 'pw'

);
$db=Zend_Db::factory($config['adapter'], $config);
$select=$db->select()
        ->from('photocontest__photos', array('*'))
        ->order('created')
        ;    
require_once 'Zend/Paginator.php';
$currentPageNumber = ($_GET['page'] > 0)?$_GET['page']:'1';
$totalNumberOfItems = 11;
$itemsPerPage = 5;
$pageRange = 10;

$adapter = new Zend_Paginator_Adapter_DbTableSelect($select);
$paginator = new Zend_Paginator($adapter);
$paginator->setCurrentPageNumber($currentPageNumber);
$paginator->setItemCountPerPage($itemsPerPage);
$scrollType = 'Sliding';
$paginator = get_object_vars($paginator->getPages($scrollType));

foreach($paginator AS $item){
    echo $item->title.'<br>';
}
?>

спасибо

######### ОБНОВЛЕНИЕ РЕДАКТИРОВАТЬ ##########

<?
$config=array(
    'adapter' => 'PDO_MYSQL',
    'hostname' => 'localhost',
    'dbname' => 'dm_xxxx',
    'username' => 'un',
    'password' => 'pw'

);
require_once 'Zend/Loader.php';
Zend_Loader::registerAutoload();
$db=Zend_Db::factory($config['adapter'], $config);
$table = new Photos(array('db' => $db));
$select = $table->select();
$select->setIntegrityCheck(false)
        ->from('photocontest__photos', array('*'))
        ->order('created')
        ;       

$currentPageNumber = ($_GET['page'] > 0)?$_GET['page']:'1';
$itemsPerPage = 6;
$adapter = new Zend_Paginator_Adapter_DbTableSelect($select); //Setup the adapter object
$paginator = new Zend_Paginator($adapter); //Setup the actual paginator object

$paginator->setCurrentPageNumber($currentPageNumber);
$paginator->setItemCountPerPage($itemsPerPage); // items pre page

$scrollType = 'Sliding'; //change this to 'All', 'Elastic', 'Sliding' or 'Jumping' to test all scrolling types

Zend_Paginator::setDefaultScrollingStyle('Sliding'); // Sliding  or  Elastic
//Zend_View_Helper_PaginationControl::setDefaultViewPartial('pagination.phtml');

$paginatorControl = get_object_vars($paginator->getPages($scrollType)); //and that's it! we can now use the $paginator variable as we want
?>
<h1>Zend_Paginator Demo</h1>
<ul id="items">
    <?php foreach($paginator AS $item): ?>
        <li><?php echo $item->title; ?></li>
    <?php endforeach ?>
</ul>

<div id="paginator">
    <p>Showing <strong><?php echo $paginatorControl['firstItemNumber'] ?> to <?php echo $paginatorControl['lastItemNumber'] ?></strong> out of <strong><?php echo $paginatorControl['totalItemCount'] ?></strong> items</p>

    <?php if($paginatorControl['previous']): ?>
        <a href="?page=<?php echo $paginatorControl['previous'] ?>">&laquo; Prev</a>
    <?php else: ?>
        <span>&laquo; Prev</span>
    <?php endif ?>

    <?php if($paginatorControl['firstPageInRange'] > $paginatorControl['first']): ?>
        <a href="?page=<?php echo $paginatorControl['first'] ?>"><?php echo $paginatorControl['first'] ?></a>
        <span>...</span>
    <?php endif ?>

    <?php foreach($paginatorControl['pagesInRange'] as $page): ?>
        <?php if($page == $paginatorControl['current']): ?>
            <span><?php echo $page ?></span>
        <?php else: ?>
            <a href="?page=<?php echo $page ?>"><?php echo $page ?></a>
        <?php endif ?>
    <?php endforeach ?>

    <?php if($paginatorControl['lastPageInRange'] < $paginatorControl['last']): ?>
        <span>...</span>
        <a href="?page=<?php echo $paginatorControl['last'] ?>"><?php echo $paginatorControl['last'] ?></a>
    <?php endif ?>

    <?php if($paginatorControl['next']): ?>
        <a href="?page=<?php echo $paginatorControl['next'] ?>">Next &raquo;</a>
    <?php else: ?>
        <span>Next &raquo;</span>
    <?php endif ?>
</div>

person EricP    schedule 24.08.2010    source источник


Ответы (1)


Отредактировано: я не думаю, что мое первое решение поможет вам, если вы не можете жить без Zend_Paginator_Adapter_DbTableSelect. Но, глядя на ваш код, вы пытались включить DbTableSelect.php напрямую?

Попробуйте использовать ::factory.

$paginator = Zend_Paginator::factory($adapter);


$paginator->setCurrentPageNumber($currentPageNumber);
$paginator->setItemCountPerPage($itemsPerPage);
$scrollType = 'Sliding';
$paginator = get_object_vars($paginator->getPages($scrollType));
person Iznogood    schedule 24.08.2010
comment
Я включил его, и теперь я получаю другую ошибку: Неустранимая ошибка: необработанное исключение "Zend_Db_Select_Exception" с сообщением "Нераспознанный метод" getTable ()" в C:\xampp\php\dev\include\ZendFramework-1.9.6\library\ Zend\Db\Select.php:1320 Трассировка стека: #0 [внутренняя функция]: Zend_Db_Select-›__call('getTable', Array) #1 C:\xampp\php\dev\include\ZendFramework-1.9.6\library \Zend\Paginator\Adapter\DbTableSelect.php(46): Zend_Db_Select->getTable() #2 C:\xampp\php\dev\include\ZendFramework-1.9.6\library\Zend\Paginator.php(750): Zend_Paginator_Adapter_DbTableSelect- ....и т.д... - person EricP; 24.08.2010
comment
Zend использует автозагрузчик для загрузки всех своих классов, и, похоже, вы не настроены на его использование. Поэтому я думаю, вам нужно включить каждый файл вручную. Вы можете опубликовать новый вопрос с этой новой информацией и получить более точную помощь. - person Iznogood; 24.08.2010
comment
Я думаю, что теперь эта часть работает, добавив: require_once('Zend/Loader.php'); Zend_Loader::registerAutoload(); Я все еще получаю сообщение об ошибке: Неустранимая ошибка: необработанное исключение «Zend_Db_Select_Exception» с сообщением «Нераспознанный метод» getTable ()». Я думаю, что это связано с тем, что я не вызываю имя моей таблицы, как я это делаю, когда я в ZF, например это: $photoTable = new Photo_Model_Photos(); $select = $photoTable-›select(); - person EricP; 25.08.2010
comment
Я заработал. Смотрите мои обновления в моем исходном посте. Мне пришлось создать класс для имени таблицы базы данных Photos.php в том же каталоге со следующим содержимым: ‹?php class Photos extends Zend_Db_Table_Abstract { protected $_name = 'photocontest__photos'; } ?› Единственное, что я не могу понять, это использование файла шаблона pagination.phtml. Он искал его в представлениях/скриптах. Поэтому я поместил его туда, но с ним были проблемы. - person EricP; 25.08.2010
comment
В моем отредактированном обновленном коде есть способ определить имя таблицы без использования: $table = new Photos(array('db' => $db)); и использовать файл класса Photos.php? Я не хочу создавать отдельные файлы только для установки имени таблицы. Я знаю, что это здорово, когда используется вся структура, но в данном случае я использую только несколько компонентов. спасибо - person EricP; 26.08.2010