0

我让 Zend Framework 提供 DRI 层的问题现在可以这样总结。

使用下面的类定义,我可以通过我的本地 UserController“public/users/delete/userId/22”删除用户但不能删除相关评论,即使我已经设置了参考映射和表关系定义。

当我删除用户记录时,为什么没有删除关联的评论记录,有没有人有任何答案?

    class Default_Model_DbTable_Comment extends Zend_Db_Table_Abstract
    {
        /**
         * @var string Name of the database table
         */
        protected $_name = 'comment';

        /**
         * @desc  reference map 
         * 
         * Rows in the comment table are to be automatically deleted if the row in the 
     * User table to which they refer is deleted
     *    
     */
     protected $_referenceMap = array(
        'User' => array(
            'columns'       => 'user_id',   // the foreign key(s)
            'refTableClass' => 'Default_Model_DbTable_Users',
            'refColumns'    =>  'id',
            'onDelete'      =>  self::CASCADE,
        )
    );

}
class Default_Model_DbTable_Users extends Zend_Db_Table_Abstract
{
    /**
     * @var string Name of the database table
     */
    protected $_name = 'users';


     /**
     * @desc Defining referential integrity here since we are using MyISAM
     * Dependent tables are referred via the class name. 
     */
    protected $_dependentTables = 'Default_Model_DbTable_Comment';



}
4

1 回答 1

0

我已经创建了您的模型,并且在测试时,它似乎仅在依赖表列在数组中时才有效:

class Default_Model_DbTable_Users extends Zend_Db_Table_Abstract
{
    /**
     * @var string Name of the database table
     */
    protected $_name = 'users';


     /**
     * @desc Defining referential integrity here since we are using MyISAM
     * Dependent tables are referred via the class name. 
     */
    protected $_dependentTables = array('Default_Model_DbTable_Comment');



}

当它们未列在数组中时,我会收到错误消息

警告:在第 632 行为 C:\PHP\includes\ZendFramework-1.8.4-minimal\library\Zend\Db\Table\Row\Abstract.php 中的 foreach() 提供的参数无效

此错误可能在您的环境中不可见。

于 2009-07-22T09:30:49.263 回答