2013-03-25 52 views
0

我创建一个过程,找出从表中缺少ID,但它并没有取得任何结果,以下是过程MySQL检索表的缺失自动增量ID的过程?

DELIMITER || 
DROP PROCEDURE IF EXISTS proc_rpt || 
CREATE PROCEDURE proc_rpt() 
BEGIN 
SET @minID = (SELECT MIN(`id`) FROM `tbl_film` WHERE `user_id`=13); 
SET @maxID = (SELECT MAX(`id`) FROM `tbl_film` WHERE `user_id`=13); 
REPEAT 
    SET @tableID = (SELECT `id` FROM `tbl_film` WHERE `id` = @minID); 
    IF (@tableID IS NULL) THEN 
     INSERT INTO temp_missing(`missing_id`) VALUES (@tableID); 
    END IF; 
    SET @minID = @minID + 1; 
UNTIL (@minID <= @maxID) 
END REPEAT; // earlier I was missing this line which was giving error in Procedure. 
END; || 

然后我致电上述

CALL rpt_proc(); 

但没有结果在tbl_missing,而我可以看到有film_idtbl_film有很多缺失的值。有人会告诉我我做错了什么吗?

回答

0

试试这段代码。

DELIMITER || 
    DROP PROCEDURE IF EXISTS proc_rpt || 
    CREATE PROCEDURE proc_rpt() 
    BEGIN 
    DECLARE maxId int; 
    DECLARE minId int; 
    DECLARE curId int; 
     SELECT MIN(`id`) INTO maxId FROM `tbl_film` WHERE `user_id`=13; 
     SELECT MAX(`id`) INTO minId FROM `tbl_film` WHERE `user_id`=13; 
    REPEAT 
     SELECT `id` INTO curId FROM `tbl_film` WHERE `id` = @minID); 
     IF (curId IS NULL) THEN 
      INSERT INTO temp_missing(`missing_id`) VALUES (curId); 
     END IF; 
     SET minId = minId + 1; 
    UNTIL (minId <= maxId) 
    END REPEAT; // earlier I was missing this line which was giving error in Procedure. 
    END; ||