mysql 存储过程 (不同数据库)从一个表复制到另一个表

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的replication来将数据库数据传送到另一个服务器的数据库MySQL的replication是一种异步的主从复制机制,可以将一个MySQL服务器上的数据同步到另一个MySQL服务器上,并保持数据的一致性。 以下是实现的步骤: 1. 在源MySQL服务器上,开启二进制日志功能,并设置server-id参数。可以通过修改my.cnf文件来配置: ``` [mysqld] log-bin=mysql-bin server-id=1 ``` 2. 在目标MySQL服务器上,设置server-id参数,并配置replication连接信息。可以通过修改my.cnf文件来配置: ``` [mysqld] server-id=2 ``` ``` CHANGE MASTER TO MASTER_HOST='source_mysql_host', MASTER_USER='replication_user', MASTER_PASSWORD='replication_password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=1234; ``` 其中,`source_mysql_host` 是源MySQL服务器的主机名或IP地址,`replication_user` 和 `replication_password` 是用于replication连接的用户名和密码,`mysql-bin.000001` 和 `1234` 是源MySQL服务器上二进制日志文件和位置的信息,需要根据实际情况进行配置。 3. 开始replication。在目标MySQL服务器上执行以下命令: ``` START SLAVE; ``` 执行完毕后,目标MySQL服务器就会开始从源MySQL服务器上同步数据。 需要注意的是,如果在源MySQL服务器上进行数据修改,需要等待replication同步完成后,才能在目标MySQL服务器上看到修改后的数据。此外,在进行replication时,需要确保源MySQL服务器和目标MySQL服务器的MySQL版本和存储引擎相同,否则可能会出现数据不一致的情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值