我有一个程序可以杀死事件调度程序中的睡眠线程。它工作正常,但有时它会引发警告,如未处理行、未获取数据、获取零行(错误编号 1329),有时还会显示未知线程(错误编号 1904)。即使我在代码中处理它。对于游标获取所有 ID 后的 1904 错误,在处理某些线程时可能会丢失,因此会引发该错误。我正在使用 MYSQL 数据库
CREATE PROCEDURE `kill_thread`()
BEGIN
DECLARE no_more_rows BOOLEAN;
DECLARE loop_cntr INT DEFAULT 0;
DECLARE num_rows INT DEFAULT 0;
DECLARE XID bigint(4);
DECLARE Sleep_Cur CURSOR FOR
SELECT ID
FROM information_schema.PROCESSLIST P
WHERE P.COMMAND='Sleep' AND P.TIME >20;
DECLARE CONTINUE HANDLER FOR NOT FOUND
SET no_more_rows = TRUE;
OPEN Sleep_Cur;
select FOUND_ROWS() into num_rows;
the_loop: LOOP
FETCH Sleep_Cur
INTO XID;
IF no_more_rows THEN
CLOSE Sleep_Cur;
LEAVE the_loop;
END IF;
SET @slp_sql= CONCAT("KILL ",XID);
PREPARE stmt FROM @slp_sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
SET loop_cntr = loop_cntr + 1;
END LOOP the_loop;
END
请为代码提出可能的修复建议,因为它正在记录到日志文件。谢谢