mysql存储过程数据迁移_用Mysql存储过程迁移数据

今天有一个需求是迁移tag的数据,之前写的存储过程到现在都忘记了,从新再写一个,并在这里纪录一下,防止自己下次还忘记 首先是修改一下Mysql的配置 大家可以看下 这是我们老大的测试结果 SET GLOBAL max_allowed_packet=1024*1024*1024;SET GLOBAL key_buf

今天有一个需求是迁移tag的数据,之前写的存储过程到现在都忘记了,从新再写一个,并在这里纪录一下,防止自己下次还忘记

首先是修改一下Mysql的配置

大家可以看下

这是我们老大的测试结果

SET GLOBAL max_allowed_packet=1024*1024*1024;

SET GLOBAL key_buffer_size=1024*1024*1024;

SET GLOBAL tmp_table_size = 512*1024*1024;

SET SESSION myisam_sort_buffer_size = 512*1024*1024;

SET SESSION read_buffer_size = 128*1024*1024;

SET GLOBAL myisam_max_sort_file_size = 100*1024*1024*1024;

下面选择数据库

use db_database;

如果有存储过程,先删除存储过程,(官方的中文翻译叫存储程序,感觉诡异)

drop procedure 存储过程名称;

好了,下面重头戏,把delimiter 改成 // 为开始和结束,并创建存储过程

delimiter //

CREATE PROCEDURE 存储过程的名称();

BEGIN

好了下面我们来定义变量,这个大家都能看懂吧!

DECLARE rid INT;

DECLARE rtags VARCHAR(225);

DECLARE lasttime datetime;

DECLARE firsttime datetime;

DECLARE done, duplicate, expcount INT DEFAULT 0;

下面这个比较特殊,是定义游标(或者叫指针,但是官网上面叫光标),这个需求要获取id,来操作后面得数据

DECLARE cur CURSOR FOR SELECT

id

FROM 表名

ORDER BY id ASC;

然后设置各种状态下的设置的变量的值

Mysql各种状态都在这里了

当sql错误状态是02000的时候 done这个变量为1

DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done = 1;

同上

DECLARE CONTINUE HANDLER FOR SQLSTATE '23000' SET duplicate = 1;

设置变量

SET lasttime = now();

SET firsttime = now();

下面我们来遍历游标

打开游标

OPEN cur;

遍历

REPEAT

FETCH cur INTO rid;

if not done then

SET duplicate = 0;

UPDATE 另一张表

SET keywords = 数据是啥

WHERE id = rid;

好了,上面就是写你的sql,下面是100条的时候,打印出来执行时间和条数

SET expcount = expcount + 1;

IF expcount % 100 = 0 then

SELECT expcount,now() - lasttime;

SET lasttime = now();

END IF;

直到没有数据,遍历结束

end if;

UNTIL done END REPEAT;

关闭游标

CLOSE cur;

最后结束存储过程

END;

//

delimiter ;

以上就是做的存储过程的数据迁移的部分,这个写的比较简单,不过以后有复杂的可以直接修改修改就可以用了!

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值