jiuchengwrong 2019-10-15 11:47 采纳率: 50%
浏览 495
已结题

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引擎,没有事务操作,没有回滚)

  • 写回答

2条回答 默认 最新

  • Json-Huang 2019-10-15 12:00
    关注

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

    评论

报告相同问题?

悬赏问题

  • ¥30 STM32 INMP441无法读取数据
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
  • ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
  • ¥30 c#打开word开启修订并实时显示批注
  • ¥15 如何解决ldsc的这条报错/index error
  • ¥15 VS2022+WDK驱动开发环境