php - Yii 事务批量插入数据
伊谢尔伦
伊谢尔伦 2017-04-10 14:43:52
[PHP讨论组]
$transaction=Yii::app()->db->beginTransaction();
try{
  $model1->save();
  $model2->save();
  $model3->save();
  $model4->save();
  $model5->save();
  //出错
  $model6->save();
  $transaction->commit();
} catch(Exception $e){
  $transaction->rollBack();
}

model1 , model2 , model3 , model4 , model5 照样存储成功!

伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回复(2)
迷茫

如果在$model6->save()可能是因为某种原因没能成功插入或更新数据,这时候会返回false,但不会有异常抛出来驱动事物回滚。你应该判断如果save时返回了false,即没有插入或更新成功,应该手动抛出Exception,这样在捕获Exception后可以rollback。

$transaction=Yii::app()->db->beginTransaction();
try{
    foreach ($models as $model) {
        if (!$model->save()) {
            throw new Exception();
        }
    }
    $transaction->commit();
} catch(Exception $e){
    $transaction->rollBack();
}
ringa_lee

先检查你的表引擎是否是innodb类型的,www.phpernote.com 提供技术支持。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号