Zend_Db_Table_Row error creating a new row

I have a table

--
-- Table structure for table `pages`
--

CREATE TABLE IF NOT EXISTS `pages` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(200) NOT NULL,
  `title` varchar(200) NOT NULL DEFAULT '',
  `text` longtext,
  `enabled` smallint(1) NOT NULL DEFAULT '0',
  PRIMARY KEY (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 ;

The form

class Admin_Form_Page extends Zend_Form
{
    public function __construct($options = null)
    {
        parent::__construct($options);
        $this->setDisableLoadDefaultDecorators(true)
            ->setElementDecorators(array(
                'ViewHelper',
                'Label',
                'Errors',
                array('HtmlTag', array('tag' => 'p'))
            ));

        $this->setDecorators(array(
            'FormElements',
            'Form'
        ));

        // Add Elements

        $this->addElement('hidden', 'id', array('decorators' => array('ViewHelper')));

        $this->addElement('text', 'name', array(
            'label' => ' ',
            'required' => true
        ));

        $this->addElement('text', 'title', array(
            'label' => ' ',
        ));

        $this->addElement('textarea', 'text', array(
            'label' => ' '
        ));

        $this->addElement('checkbox', 'enabled', array(
            'label' => ' '
        ));

        $this->addElement('submit', 'save', array(
            'label' => '',
            'decorators' => array(
                'ViewHelper',
                array('HtmlTag', array('tag' => 'p'))
            )
        ));
    }
}

and model

class Default_Model_Pages extends Zend_Db_Table
{
    protected $_name = 'pages';

    protected $_cols = array('id', 'name', 'title', 'text', 'enabled');

    protected $_primary = 'id';

    public function getPagesList($enabled = true)
    {
        $sql = $this->select();
        if (true === $enabled) $sql->where('enabled = 1');
        return $this->fetchAll($sql)->toArray();
    }
}

then I will not create a new page with Zend_Db_Table_Row

...
$pageData = $pageForm->getValues();
$id = (!empty($pageData['id'])) ? (int) $pageData['id'] : null;

$pageRow = (null === $id)
    ? $pageTable->createRow($pageData)
    : $pageTable->fetchRow($pageTable->select()->where('id = ?', $id))->setFromArray($pageData);

if ($pageRow->save()) {
    $this->view->content = '<p class="info">Save Ok</p>';
} else {
    $this->view->content = '<p class="error">Save error</p>';
}

i has an error

Fatal error: Uncaught exception 'Zend_Db_Table_Row_Exception' with message 'Cannot refresh row as parent is missing' in /home/ergallm/www/gps.local/library/Zend/Db/Table/Row/Abstract.php on line 764 Zend_Db_Table_Row_Exception: Cannot refresh row as parent is missing in /home/ergallm/www/gps.local/library/Zend/Db/Table/Row/Abstract.php on line 764 Call Stack: 0.0002 657224 1. {main}() /home/ergallm/www/gps.local/public/index.php:0 0.0509 8922848 2. Zend_Application->run() /home/ergallm/www/gps.local/public/index.php:16 0.0509 8922848 3. Zend_Application_Bootstrap_Bootstrap->run() /home/ergallm/www/gps.local/library/Zend/Application.php:366 0.0509 8922984 4. Zend_Controller_Front->dispatch() /home/ergallm/www/gps.local/library/Zend/Application/Bootstrap/Bootstrap.php:97

if i unset $ pageData ['id']

$pageData = $pageForm->getValues();
$id = (!empty($pageData['id'])) ? (int) $pageData['id'] : null;
unset($pageData['id']);

i has an error

Notice: Undefined index: id in /home/ergallm/www/gps.local/library/Zend/Db/Table/Row/Abstract.php on line 745 Call Stack: 0.0002 657224 1. {main}() /home/ergallm/www/gps.local/public/index.php:0 0.0448 8922848 2. Zend_Application->run() /home/ergallm/www/gps.local/public/index.php:16 0.0448 8922848 3. Zend_Application_Bootstrap_Bootstrap->run() /home/ergallm/www/gps.local/library/Zend/Application.php:366 0.0449 8922984 4. Zend_Controller_Front->dispatch() /home/ergallm/www/gps.local/library/Zend/Application/Bootstrap/Bootstrap.php:97 0.0467 9404896 5. Zend_Controller_Dispatcher_Standard->dispatch() /home/ergallm/www/gps.local/library/Zend/Controller/Front.php:954 0.0497 9895472 6. Zend_Controller_Action->dispatch() /home/ergallm/www/gps.local/library/Zend/Controller/Dispatcher/Standard.php:295 0.0497 9903880 7. Admin_IndexController->pagesAction() /home/ergallm/www/gps.local/library/Zend/Controller/Action.php:513 0.0643 13499456 8. Zend_Db_Table_Row_Abstract->save() /home/ergallm/www/gps.local/application/modules/admin/controllers/IndexController.php:29 0.0643 13499456 9. Zend_Db_Table_Row_Abstract->_doInsert() /home/ergallm/www/gps.local/library/Zend/Db/Table/Row/Abstract.php:438 0.0656 13504264 10. Zend_Db_Table_Row_Abstract->_refresh() /home/ergallm/www/gps.local/library/Zend/Db/Table/Row/Abstract.php:497 0.0656 13504264 11. Zend_Db_Table_Row_Abstract->_getWhereQuery() /home/ergallm/www/gps.local/library/Zend/Db/Table/Row/Abstract.php:759

What am I doing wrong?

+3
source share
2 answers

I think the problem is that you assign the variable yourself $_cols. When you do this, Zend_Db_Table will not be properly initialized. According to the Zend Framework link , to specify columns, you must overwrite the describeTable () method:

_setupMetadata() , "Schema.table"; describeTable() ; $_cols Table(). , .

: .

, Default_Model_Pages , _setupMetadata() Zend_Db_Table_Abstract . , _primary _cols . Default_Model_Pages , _setupMetadata . , , protected $_primary = 'id'; . $_primary , _setupMetadata() _setupPrimaryKey().

+4

cols :

$table = new YourTable();
$cols = $table->info(Zend_Db_Table_Abstract::COLS);

:

$this->info(Zend_Db_Table_Abstract::COLS)
0

Source: https://habr.com/ru/post/1795404/


All Articles