您好,欢迎访问一九零五行业门户网

用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 selectidfrom 表名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;
遍历
repeatfetch cur into rid;if not done thenset 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 ;
以上就是做的存储过程的数据迁移的部分,这个写的比较简单,不过以后有复杂的可以直接修改修改就可以用了!
其它类似信息

推荐信息