1

这是我的代码:

$transaction = Yii::app()->db->beginTransaction();
            try {
                $tModel->save();
                $activationLink = new ActivationLink;
                $activationLink->User_id = $tModel->id;
                $activationLink->hash1   = User::generateHashCode(100);
                $activationLink->hash2   = User::generateHashCode();
                $activationLink->hash3   = User::generateHashCode();
                $activationLink->time    = time();
                $activationLink->save();                    
                User::sendActivatonLink($tModel->mail,$activationLink->id, $activationLink->hash1, $activationLink->hash2, $activationLink->hash3);
                $transaction->commit();
                $this->redirect(array('view', 'id' => $tModel->id));
            } catch (Exception $e) {
                $transaction->rollback();
                Yii::app()->user->setFlash('error', "{$e->getMessage()}");
                $this->refresh();
            }

$tModel保存但$activationLink没有,所以它应该回滚。但它没有,为什么?

4

2 回答 2

8

Yii save() 不会抛出异常,只是验证失败。因此,您必须自己检查 save() 的结果:

if (!$model->save())
   $transaction->rollback();

//or:

if (!$model->save())
   throw new Exception("This will trigger my catch statement block");
于 2012-12-10T13:48:17.157 回答
1

请检查你的mysql引擎我认为你没有使用innodb。要执行事务,我们必须使用 innodb。让我知道您的表类型/引擎。

或者您还需要添加代码以了解日志中的错误。

抛出新异常($e);

于 2012-12-09T18:06:10.000 回答