0

我有一个大型数据集,需要在发布到服务器时写入数据库,但可能是客户端编辑器中的错误添加了触发“完整性约束违规”的额外记录。

我的问题是,当我到达触发错误的数据点时,数据库中已经更新了很多以前的数据。我需要回滚并拒绝发布的数据。

这是我的控制器的操作。

/**
 * Handles saving data from the network editor.
 */
public function json_save()
{
    if($this->request->is('post'))
    {
        $result = array();
        $data = $this->request->input('json_decode');
        if(isset($data->network_id) && !empty($data->network_id))
        {
            $dataSource = $this->Node->getDataSource();
            $dataSource->begin();

            $result['nodes'] = $this->updateModel($data->network_id, $this->Node, 'nodes', $data, array(
                'ParamValue'
            ));
            $result['connections'] = $this->updateModel($data->network_id, $this->Connection, 'connections', $data);

            $dataSource->commit();

            $this->viewClass = 'Json';
            $this->set('result', $result);
            $this->set('_serialize', array(
                'result'
            ));

            return;
        }
    }

    throw new ErrorException('Posted data missing.');
}

我的控制器updateModel功能对模型$this->Node$this->Connection.

如何回滚通常在更新$this->Connection模型期间抛出的“完整性约束违规”。

我不确定它是否是我可以捕获然后执行回滚的 PHP 异常,或者是否有不同的方法来捕获它。

4

1 回答 1

3

你可以做一个:

$dataSource->begin();

try {
  // The queries here.
} catch (Exception $e) {
  $dataSource->rollback();
  throw $e;
}

$dataSource->commit();
于 2013-04-08T16:33:55.680 回答