mysql 存储过程中如何使事务生效
在我的存储过程中,需要将一个表中的数据分散插入到多个表中,但是这些表并不在同一个数据库中,现我使用游标遍历这个表,然后将此表的每条记录拼写成多个insert语句插入多表,...
在我的存储过程中,需要将一个表中的数据分散插入到多个表中,但是这些表并不在同一个数据库中,现我使用游标遍历这个表,然后将此表的每条记录拼写成多个insert语句插入多表,因为需要保持数据一致性,我想在循环中加上事务控制,大致语句如下:
DECLARE cursortemp CURSOR FOR select * from t;
OPEN cursortemp;
record: LOOP
FETCH cursortemp INTO a,b,c,d,e,...;
START TRANSACTION;
insert into t1( c1,c2,c3) values(a,b,c);
insert into t2( c1,c2) values(b,c);
insert into t1( c1,c2,c3) values(c,d,e);
COMMIT;
END LOOP record;
CLOSE cursortemp;
如上写法,事务并没有生效,是我写的不对还是不支持跨数据库事务呢,还请mysql高手指点。 展开
DECLARE cursortemp CURSOR FOR select * from t;
OPEN cursortemp;
record: LOOP
FETCH cursortemp INTO a,b,c,d,e,...;
START TRANSACTION;
insert into t1( c1,c2,c3) values(a,b,c);
insert into t2( c1,c2) values(b,c);
insert into t1( c1,c2,c3) values(c,d,e);
COMMIT;
END LOOP record;
CLOSE cursortemp;
如上写法,事务并没有生效,是我写的不对还是不支持跨数据库事务呢,还请mysql高手指点。 展开
若以下回答无法解决问题,邀请你更新回答
1个回答
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询