开发者社区> 问答> 正文

mysql批量插入时,若有一条报错,则上一条的触发器不执行 ?报错

现有一张表 frm_72 和一张记录自增id的表 cmpp_frm,
frm_72 上写了触发器如下:

BEGIN 
declare testid int; 
update cmpp_frm set auto_id = auto_id + 1  where id=72; 
select auto_id  into @testid from cmpp_frm where id=72; 
set new.id =  @testid; 
END

当 frm_72 有新数据插入时,让cmpp_frm 的auto_id字段+1,并获得值做id。

单条插入时执行正常。

批量插入2条时(设语句1正常,语句2报错),若 auto_id 初始是1, 正常应该 语句1 的id 是2,auto_id 字段是2,语句2报错,auto_id不变。

但是,运行结果是 auto_id 仍是 1,语句1 的id 是2,语句2报错。

不知道为什么触发器中的 update 没有执行,但 select 却得到了自增后的结果

(分表原因用的是myisam引擎,没有事务操作,没有回滚)

展开
收起
爱吃鱼的程序员 2020-06-22 23:46:02 449 0
1 条回答
写回答
取消 提交回答
  • https://developer.aliyun.com/profile/5yerqm5bn5yqg?spm=a2c6h.12873639.0.0.6eae304abcjaIB

    可以考虑用事务,保证所有操作成功才执行,否则回滚

    有可能在执行第二条语句后做了事务回滚。试一试每条插入语句后提交一下事务

    2020-06-22 23:46:19
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
One Box: 解读事务与分析一体化数据库 HybridDB for MySQL 立即下载
One Box:解读事务与分析一体化数据库HybridDB for MySQL 立即下载
如何支撑HTAP场景-HybridDB for MySQL系统架构和技术演进 立即下载

相关镜像