Связи нескольких таблиц в Zend Help - PullRequest
0 голосов
/ 02 мая 2010

Я делал некоторые сопоставления БД, чтобы связать две таблицы безрезультатно.Каждый раз, когда я запускаю код, я получаю следующую ошибку:

Message: File "Role.php" does not exist or class "Role" was not found in the file

Stack trace:

#0 C:\wamp\www\zend\library\Zend\Db\Table\Row\Abstract.php(867): Zend_Db_Table_Row_Abstract->_getTableFromString('Role')
#1 C:\wamp\www\uw\application\models\admin\User.php(56): Zend_Db_Table_Row_Abstract->findDependentRowset('Role')
#2 C:\wamp\www\uw\application\controllers\AdminController.php(110): Application_Model_Admin_User->getUsers()
#3 C:\wamp\www\zend\library\Zend\Controller\Action.php(513): AdminController->usersAction()
#4 C:\wamp\www\zend\library\Zend\Controller\Dispatcher\Standard.php(289): Zend_Controller_Action->dispatch('usersAction')
#5 C:\wamp\www\zend\library\Zend\Controller\Front.php(954): Zend_Controller_Dispatcher_Standard->dispatch(Object(Zend_Controller_Request_Http), Object(Zend_Controller_Response_Http))
#6 C:\wamp\www\zend\library\Zend\Application\Bootstrap\Bootstrap.php(97): Zend_Controller_Front->dispatch()
#7 C:\wamp\www\zend\library\Zend\Application.php(366): Zend_Application_Bootstrap_Bootstrap->run()
#8 C:\wamp\www\uwi\public\index.php(26): Zend_Application->run()
#9 {main}

Код и БД:

application / models / admin / User.php

class Application_Model_Admin_User extends Zend_Db_Table_Abstract
{
 protected $_name = 'user';
 protected $_dependentTables  = array('Role');

 public function getUsers()
 {  
  $rows = $this->fetchAll($this->select()->where('active = ?', 1));
  $rows1 = $rows->current();
  $rows2 = $rows1->findDependentRowset('Role');
  return $rows2;
 }
}

приложение / модели / admin / Role.php

class Application_Model_Admin_Role extends Zend_Db_Table_Abstract
{
 protected $_name = 'role';
 protected $_referenceMap = array (
 'Role' => array(
  'columns'           => array('id'),
  'refTableClass'     => 'User',
  'refColumns'        => array('role_id')
 );

}

таблицы БД

CREATE TABLE role (
   id integer auto_increment NOT NULL,
   name varchar(120),
   PRIMARY KEY(id)
);

CREATE TABLE user (
   id integer auto_increment NOT NULL,
   username varchar(120),
   PRIMARY KEY(id),
   FOREIGN KEY(role_id) REFERENCES role(id)
);

1 Ответ

3 голосов
/ 03 мая 2010

Сообщение об ошибке дает вам отличный совет!

Есть ли в вашем приложении класс с именем "Role"? Или это называется Application_Model_Admin_Role?

...