概述
begin
DELETE FROM test_cpos_store.t_sn_mc_market;
-- 声明一个标志done, 用来判断游标是否遍历完成
DECLARE done INT DEFAULT 0;
-- 声明一个变量,用来存放从游标中提取的数据
-- 特别注意这里的名字不能与由游标中使用的列明相同,否则得到的数据都是NULL
DECLARE marketCode char(3);
DECLARE financeEmail varchar(400);
DECLARE id,barndCode,brandName,brancNameCn,brandNameEn,marketName varchar(100);
DECLARE delSql varchar(100);
#DELETE FROM t_sn_mc_market WHERE 1 =1 ;
-- 声明游标对应的 SQL 语句
DECLARE cur CURSOR FOR select GUID,BRAND_CODE,BRAND_NAME_CN,BRAND_NAME_EN,MARKET_CODE,MARKET_NAME,FINANCE_EMAIL FROM t_sn_mc_market;
-- 在游标循环到最后会将 done 设置为 1
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
-- 执行查询
open cur;
-- 遍历游标每一行
REPEAT
-- 把一行的信息存放在对应的变量中
FETCH cur INTO id,barndCode,brancNameCn,brandNameEn,marketCode,marketName,financeEmail;
if not done then
-- 这里就可以使用 tname, tpass 对应的信息了
#if (select count(1) from hx_message_user where uid=tid) = 0 THEN
INSERT INTO test_cpos_store.t_sn_mc_market(GUID,BRAND_CODE,BRAND_NAME_CN,BRAND_NAME_EN,MARKET_CODE,MARKET_NAME,FINANCE_EMAIL) VALUES(id,barndCode,brancNameCn,brandNameEn,marketCode,marketName,financeEmail);
#end if;
#select tid,tname, tpass,(select count(1) from btable where id=tid) as count;
end if;
UNTIL done END REPEAT;
CLOSE cur;
end
最后
以上就是愤怒微笑为你收集整理的mysql 存储过程 (不同数据库)从一个表复制到另一个表的全部内容,希望文章能够帮你解决mysql 存储过程 (不同数据库)从一个表复制到另一个表所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复