Heim >Datenbank >MySQL-Tutorial >Gespeicherte MySQL-Prozedur -> Migrieren Sie Daten durch Cursordurchquerung und Ausnahmebehandlung in die Verlaufstabelle
-- Große Tabellendatenmigration,Jeden Morgen1Klicken Sie auf 5Klicken Sie, um auszuführen , Ausführungsintervall beträgt 10 Minuten, alte Daten in die Verlaufstabelle migrieren.
DELIMITER $$ USE `dbx`$$ DROP PROCEDURE IF EXISTS `pro_xx`$$ CREATE PROCEDURE `pro_xx`() BEGIN DECLARE p_oalid INT DEFAULT 0; DECLARE STOP INT DEFAULT 0; DECLARE cur_oalid CURSOR FOR SELECToal.id FROM oal_xxx oal WHERE oal.`ymd` <CONCAT(YEAR(DATE_ADD(NOW(),INTERVAL -1 MONTH)),'-',MONTH(DATE_ADD(NOW(),INTERVAL -1 MONTH )),'-', DAY(DATE_ADD(NOW(),INTERVAL-1 MONTH ))) LIMIT 1000; DECLARE EXIT HANDLER FOR SQLSTATE '02000' /**包含游标not found*/ BEGIN SET STOP=1; INSERTINTO db_logs(log_type,table_name,action_name,log_msg,create_time) SELECT1, 'oal_xxx','pro_oal_log_move',CONCAT('primary key:',p_oalid,' 游标执行正常结束!'),NOW(); END; DECLARE EXIT HANDLER FOR SQLEXCEPTION BEGIN SETSTOP=1; INSERTINTO db_logs(log_type,table_name,action_name,log_msg,create_time) SELECT2, 'oal_xxx','pro_oal_log_move',CONCAT('primary key:',p_oalid,' 移动执行失败'),NOW(); END; OPEN cur_oalid;
-- Eine Datenzeile in die Variable einlesen
FETCH cur_oalid INTO p_oalid;
-- Damit wird festgestellt, ob der Cursor das Ende erreicht hat
WHILE STOP <> 1 DO -- select p_id; START TRANSACTION;
🎜>Lesen Sie die Daten der nächsten Zeile.
REPLACE INTO oal_xxx_history SELECT oal.*FROM oal_xxx oal WHERE oal.id=p_oalid ; DELETE FROM oal_xxx WHERE id=p_oalid; -- INSERT INTO t (tid) VALUES (p_tid); COMMIT;
Das Obige ist der Inhalt der gespeicherten MySQL-Prozedur --> Daten migrieren Die Verlaufstabelle durch Cursordurchquerung und Ausnahmebehandlung, weitere verwandte Inhalte. Bitte beachten Sie die chinesische PHP-Website (www.php.cn)!