我正在使用默认的Zend_Db_Table_Abstract来设置关系。这些是我的模特:
Model_Table_Project:
protected $_name = 'projects';
protected $_dependentTables = array('Model_Table_ProjectStage');
protected $_referenceMap = array(
'User' => array(
'columns' => 'userId',
'refTableClass' => 'Model_Table_User',
'refColumns' => 'id'
)
);
public function deleteProject($id)
{
$row = $this->find($id)->current();
if ($row)
{
$row->delete();
}
else
{
throw new Zend_Exception('Cannot delete project.');
}
}
Model_Table_Stage:
protected $_name = 'stages';
protected $_dependentTables = array('Model_Table_ProjectStage');
Model_Table_ProjectStage:
protected $_name = 'projectstage';
protected $_referenceMap = array(
'Project' => array(
'columns' => 'projectId',
'refTableClass' => 'Model_Table_Project',
'refColumns' => 'id',
'onDelete' => self::CASCADE,
),
'Stage' => array(
'columns' => 'stageId',
'refTableClass' => 'Model_Table_Stage',
'refColumns' => 'id',
'onDelete' => self::CASCADE,
)
);
现在,当我想使用Model_Table_Project中的deleteProject()方法删除项目时,它会删除Project表中的条目和ProjectStage表中的条目,但它不会删除Stage表中的条目。
我做错了什么?
答案 0 :(得分:0)
我找到了解决方案。这是我自己的思维错误。我现在使用的解决方案是:
在Table模型中,我调用$ row-> delete(),在Row模型中我声明了一个删除方法:
public function delete()
{
$stages = $this->getStages();
foreach ($stages as $stage)
{
$stage->delete();
}
return parent::delete();
}
这样它首先删除所有相关的阶段,然后删除自己。