Heim >Datenbank >MySQL-Tutorial >Detaillierte Erläuterung der gespeicherten Prozeduren, Cursor und Transaktionen von MySQL

Detaillierte Erläuterung der gespeicherten Prozeduren, Cursor und Transaktionen von MySQL

小云云
小云云Original
2018-05-17 09:34:112689Durchsuche

In diesem Artikel werden hauptsächlich relevante Informationen zu gespeicherten Prozeduren, Cursorn und Transaktionen von MySQL vorgestellt. Hier finden Sie Beispiele zur Veranschaulichung von gespeicherten MySQL-Prozeduren, Cursorn und Transaktionen Ich hoffe, es kann allen helfen.

Empfohlene MySQL-Video-Tutorials: „MySQL-Tutorial

Detaillierte Erläuterung der gespeicherten Prozeduren, Cursor und Transaktionsinstanzen von MySQL

Das Folgende ist eine gespeicherte MySQL-Datenbankprozedur, die ich als Archiv für die zukünftige Verwendung behalte.

Daunter sind gespeicherte Prozeduren, Cursor (doppelstufige Schleifen) und Transaktionen beteiligt.

[Hinweis]: Die Kommentare im Code sind nur für das jeweilige Unternehmen bestimmt und müssen nicht ignoriert werden.

Der Code lautet wie folgt:

DELIMITER $$
DROP PROCEDURE IF EXISTS `transferEmailTempData`$$

CREATE PROCEDURE transferEmailTempData(IN jobId VARCHAR(24))
BEGIN
  DECLARE idval VARCHAR(24) DEFAULT '';
  DECLARE taskIdval VARCHAR(24) DEFAULT '';
  DECLARE groupIdval VARCHAR(24) DEFAULT '';
  DECLARE emailval VARCHAR(50) DEFAULT '';
  
  /*标识正式表是否存在一条相同数据,即:groupId、email相同*/
  DECLARE infoId VARCHAR(24) DEFAULT '';
  
  /*标识事务错误*/
  DECLARE err INT DEFAULT 0;
  
  /*达到一定数量就进行提交,计数器*/
  DECLARE counts INT DEFAULT 0;
  
  /*标识是否回滚过*/
  DECLARE isrollback INT DEFAULT 0;
  
  /*游标遍历时,作为判断是否遍历完全部记录的标记*/
  DECLARE done INTEGER DEFAULT 0;
  
  /*获取临时表该任务的数据*/
  DECLARE cur CURSOR FOR SELECT id,taskId,groupId,email FROM `t_email_data_temp` WHERE taskId=jobId;
  
  /*根据群组id、email查询是否存在相同记录*/
  DECLARE cur2 CURSOR FOR SELECT id FROM `t_email_info` e WHERE e.`group_id` = groupIdval AND e.`email_address` = emailval; 
  
  /* 出现错误,设置为1,只要发生异常就回滚*/
  DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET err=1;
  
  /*声明当游标遍历完全部记录后将标志变量置成某个值*/
  DECLARE CONTINUE HANDLER FOR NOT FOUND
  SET done=1;
  
  /*开启事务*/
  START TRANSACTION;
  
  /*打开游标*/
  OPEN cur;
  
  /*使用LOOP循环遍历*/
  out_loop:LOOP
  
    /*将每一条结果对应的字段值赋值给变量*/
    FETCH cur INTO idval,taskIdval,groupIdval,emailval;
    IF done = 1 THEN
      LEAVE out_loop;
    END IF;
    
    /*打开第二个游标*/
    OPEN cur2;
      SET done = 0;
      FETCH cur2 INTO infoId;
      
      /*如果正式表不存在相同groupId and email记录,添加到正式表*/
      IF done = 1 THEN
      
        /*插入正式表*/
        INSERT INTO `t_email_info` VALUES(idval,emailval,groupIdval,0,'',NOW(),'admin',NOW(),'admin');
        
        /*删除临时数据*/
        DELETE FROM `t_email_data_temp` WHERE id = idval;
        
        /*计数器,每1000条才提交*/
        SET counts = counts + 1;
        
        /*发生异常,回滚*/
        IF err=1 THEN
          SET isrollback=1;
          ROLLBACK;
        ELSE
          IF counts = 1000 THEN
            COMMIT;
            /*达到1000条提交后,重置计数器*/
            SET counts=0;
          END IF;
        END IF;
      ELSE
        /*已经存在相同记录,则删除该记录*/
        IF done=0 THEN
          DELETE FROM `t_email_data_temp` WHERE id = idval;
        END IF;
      END IF;
      FETCH cur2 INTO infoId;
    CLOSE cur2;
    
    /*控制外部的循环,该步骤不能缺少,否则只循环一次就结束了*/
    SET done=0;
    
  END LOOP out_loop;
  CLOSE cur;
  
  /*如果没有发生过回滚事件,则更新task状态*/
  /*如果回滚过,不更新task状态,下次执行任务的时候,会再次将剩余没有提交的数据进行添加到正式表*/
  IF isrollback=0 THEN
    UPDATE `t_email_task` t SET t.`if_finish` = 1 WHERE t.`id`=jobId;
  END IF;
  
  END$$

DELIMITER ;

Verwandte Empfehlungen:

Eine kurze Einführung in gespeicherte MySQL-Prozeduren und -Transaktionen

So definieren, ändern und löschen Sie gespeicherte Prozeduren

Beispielcode für die Cursor-Fehlerbehandlung gespeicherter MySQL-Prozeduren

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der gespeicherten Prozeduren, Cursor und Transaktionen von MySQL. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn