Rumah > pembangunan bahagian belakang > tutorial php > 使用游标将数据更新,陷入死循环,求解释

使用游标将数据更新,陷入死循环,求解释

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Lepaskan: 2016-06-23 14:18:13
asal
1012 orang telah melayarinya

数据迁移
要将老的数据库里面的数据导入到新的数据库。
数据表不一样,只是有些字段一样。
我要
将这个库里面的user 表的数据导入到
NEW_DB的`USER_ACCOUNT表,下面这样居然陷入了循环,运行了十几分钟

DELIMITER $$CREATE DEFINER=`root`@`localhost` PROCEDURE `pr_test3`()BEGIN  DECLARE p_username VARCHAR(20);  DECLARE p_email VARCHAR(20) ;    DECLARE Done INT;    #得到游标,选择老的表里面的username和emailDECLARE rs CURSOR FOR SELECT username,email FROM  user LIMIT 100;  DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET Done = 1;    OPEN rs;FETCH NEXT FROM rs INTO p_username,p_email;  #开始遍历  REPEAT  IF NOT Done THEN  #执行需要的操作    SELECT @p_username;#插入到新的库的表  INSERT INTO NEW_DB.`USER_ACCOUNT` (USERID,`PASSWORD`,`EMAIL`,`REGTIME`,`MODTIME`) VALUES (p_username,,'123456',p_email,NOW(),NOW()); #下一条 FETCH NEXT FROM rs INTO p_username,p_email;  END IF;  UNTIL Done END REPEAT;  CLOSE rs;  END$$DELIMITER ;
Salin selepas log masuk


回复讨论(解决方案)

因为你加了limit 100的限制,怎么也不可能出现SQLSTATE '02000'

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan