码迷,mamicode.com
首页 > 数据库 > 详细

mysql 存储过程实现搬表

时间:2017-11-29 17:05:04      阅读:185      评论:0      收藏:0      [点我收藏+]

标签:mysql   存储过程   

实现简单搬表,使用游标循环

第一行 DELIMITER //和最后一行的//必须,否则遇到分号就报错

DELIMITER //
create procedure movedata()
BEGIN
      DECLARE Done INT DEFAULT 0;
     
      DECLARE v_id VARCHAR(30);
      /* 声明游标 */
      DECLARE rs CURSOR FOR SELECT id FROM `new`.customer;
      /* 异常处理 */
      DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET Done = 1;
     
      /* 打开游标 */
      OPEN rs;  
     
      /* 逐个取出当前记录LingQi字段的值,需要进行最大值的判断 */
      FETCH  rs INTO v_id;     
      /* 遍历数据表 */
     REPEAT
            IF NOT Done THEN
               insert into `old`.customer(id,idcard_no) (select id+100000,idcard_no from `new`.customer where id = v_id);
            END IF;
           
      FETCH rs INTO v_id;
 
      UNTIL Done END REPEAT;
     
      /* 关闭游标 */
      CLOSE rs;
 END
 //


mysql 存储过程实现搬表

标签:mysql   存储过程   

原文地址:http://blog.51cto.com/1385903/2045676

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!