请问yii2的事务 具体是怎么执行的,为什么我sql出错后不会回滚呢?-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

请问yii2的事务 具体是怎么执行的,为什么我sql出错后不会回滚呢?

2016-07-04 14:54:59 2294 1

我设置了 关联表的 添加和删除操作的事务.afterSave,beforeDelete

正常情况下,关联操作没有问题. A,B 2表 数据都是符合预期的.

我在 数据库中 叫B表 表名修改. 这个时候sql语句肯定是执行不了的. yii直接报错(这也是对的,因为找不到相关的表.)

报错后再查看数据库, A表记录已经删除, 但B表记录任然存在.

我的疑问是, B表的记录存在是对的.因为sql没有执行成功. 但A表的记录为什么也被删除了? 已经启用事务.为什么不回滚呢?

我水平很菜,是不是我对事务的理解错误.

是不是说?事务只是针对 数据库基本操作正常的情况下才会有效.

比如只是逻辑错误的时候,才需要人为(当然这里是框架帮我们搞了)的触发回滚,已达到事务的操作需求?

取消 提交回答
全部回答(1)
  • a123456678
    2019-07-17 19:50:41
    public function transactions()
    {
        return [
            self::SCENARIO_DEFAULT => self::OP_INSERT | self::OP_DELETE
        ];
    }
    0 0
相关问答

5

回答

Spark 【问答合集】

社区小助手 2019-05-29 14:13:40 129498浏览量 回答数 5

20

回答

【大咖问答】对话PostgreSQL 中国社区发起人之一,阿里云数据库高级专家 德哥

阿里ACE 彭飞 2019-07-10 09:36:10 1221666浏览量 回答数 20

145

回答

【新手入门】云服务器linux使用手册

fanyue88888 2012-11-26 17:14:18 159393浏览量 回答数 145

8

回答

OceanBase 使用动画(持续更新)

mq4096 2019-02-20 17:16:36 340435浏览量 回答数 8

38

回答

[@饭娱咖啡][¥20]对于慢sql有没有什么比较实用的诊断和处理方法?

江小白太白 2018-10-30 18:47:38 143830浏览量 回答数 38

22

回答

爬虫数据管理【问答合集】

我是管理员 2018-08-10 16:37:41 148512浏览量 回答数 22

2

回答

mySQL数据库报错You have an error in your SQL syntax

落地花开啦 2016-02-14 16:09:24 133135浏览量 回答数 2

8

回答

flink sql 支持checkpoints吗?

游客izljdlkgbdwfc 2019-07-10 17:46:37 125671浏览量 回答数 8

39

回答

安全组详解,新手必看教程

我的中国 2017-11-30 15:23:46 262853浏览量 回答数 39

21

回答

请教一下数据量有100万条左右要什么配置?

易网网络 2013-03-27 15:18:02 193520浏览量 回答数 21
+关注
0
文章
14879
问答
问答排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载