现有一张表 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引擎,没有事务操作,没有回滚)
可以考虑用事务,保证所有操作成功才执行,否则回滚
有可能在执行第二条语句后做了事务回滚。试一试每条插入语句后提交一下事务
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。