我正在将SQL Server 2005数据库转换为MySQL,并且存储过程遇到问题。我是MySQL存储过程的新手,因此我确定转换存在问题,但我没有看到它。

该存储过程应该生成一个临时表,该表用于填充vb.net应用程序中的数据网格视图。但是,我收到错误“数据无数据-零行被读取,选择或处理”。看起来很简单,但是如果我只是将它作为查询运行,则存储过程中的选择过程将获取数据,这就是为什么我不明白为什么会出错的原因。

我真的希望有人能告诉我为什么,因为我要转换数百个存储过程,而我在第一个问题上就遇到了这个问题。

这是存储过程:

DELIMITER $$

DROP PROCEDURE IF EXISTS `usp_get_unassigned_media`$$

CREATE DEFINER=`showxx`@`67.111.11.110` PROCEDURE `usp_get_unassigned_media`()
BEGIN
    /* GET CURSOR WITH LOCAL LOCATIONS */
    DECLARE intKey INT;
    DECLARE dteDateInserted DATETIME;
    DECLARE vchIdField VARCHAR(200);
    DECLARE vchValueField VARCHAR(200);
    DECLARE intLastKey INT;


/*TAKE OUT SPECIFIC PLAYLIST ITEMS IF TOO SLOW*/
DECLARE csrMediaToBeAssigned CURSOR FOR
SELECT
  `media`.`key`             AS `key`,
  `media`.`date_inserted`   AS `date_inserted`,
  `media_detail_types`.`id` AS `id`,
  `media_details`.`value`   AS `value`
FROM (`media`
   LEFT JOIN (`media_detail_types`
          JOIN `media_details`
        ON ((`media_detail_types`.`key` = `media_details`.`detail_key`)))
     ON ((`media_details`.`media_key` = `media`.`key`)))

WHERE ((`media`.`is_assigned` = 0)
       AND ((`media_detail_types`.`id` = 'Volume Name')
         OR (`media_detail_types`.`id` = 'Drive Id')))
ORDER BY `media`.`key`,`media`.`date_inserted`,`media_detail_types`.`id`;

OPEN csrMediaToBeAssigned;

DROP TEMPORARY TABLE IF EXISTS temp_unassigned_media;
CREATE TEMPORARY TABLE temp_unnassigned_media
    (temp_key INT, DateInserted DATETIME, IdField VARCHAR(200), ValueField VARCHAR (200))
    ENGINE=MEMORY;
SET intLastKey = 0;
/*--GET FIRST RECORD */

FETCH FROM csrMediaToBeAssigned
    INTO intKey, dteDateInserted, vchIdField, vchValueField;
/*--LOOP THROUGH CURSOR */
WHILE intLastKey = 0 DO
    /*--DATA SHOULD BE IN DRIVE ID THEN VOLUME NAME */

    INSERT INTO  temp_unnassigned_media
        VALUES (intKey, dteDateInserted, vchValueField, '');
    FETCH NEXT FROM csrMediaToBeAssigned
        INTO intKey, dteDateInserted, vchIdField, vchValueField;

    UPDATE temp_unnassigned_media
        SET IdField = vchValueField
        WHERE temp_key = temp_key;
    FETCH NEXT FROM csrMediaToBeAssigned
        INTO intKey, dteDateInserted, vchIdField, vchValueField;

END WHILE;
SELECT *
    FROM temp_unnassigned_media
    ORDER BY date_inserted;
CLOSE csrMediaToBeAssigned;
/*DEALLOCATE csrMediaToBeAssigned   */
/*DROP TABLE #temp_unnassigned_media    */

END$$

DELIMITER ;

最佳答案

您永远不会遇到WHILE循环将退出的情况。您可以初始化intLastKey变量,但是它永远不会改变,因此您可以获取整个结果集。在最后一条记录之后再次获取时,将引发异常。

规范模式是声明CONTINUE HANDLER,当触发NOT FOUND条件时,MySQL将执行该DECLARE CURSOR。该处理程序通常用于设置一个变量,然后可以对其进行测试,以便知道何时退出循环。

就您而言,看起来只需在OPEN语句之后和语句之前添加以下行即可:

DECLARE CONTINUE HANDLER FOR NOT FOUND SET intLastKey = 1;

关于mysql - 存储过程中无数据错误,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/13957507/

10-16 22:33