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高手指点。
展开
 我来答
若以下回答无法解决问题,邀请你更新回答
liuning_688
2012-04-23 · 超过38用户采纳过TA的回答
知道答主
回答量:229
采纳率:0%
帮助的人:133万
展开全部
你要用3个 存储进程分别调用
追问
没明白,能否说详细些?
追答
因为你的3个表在不同的数据库 所以针对每个数据库写一个存储过程 分别对各个数据库进行insert操作
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式