6

我可以在 if 语句中声明游标吗?

如果可能的话,我怎么能做到?

因为我刚刚做了这样的光标

CREATE FUNCTION `fn_test`(
    ProductID BIGINT(20)
)
RETURNS DECIMAL(10,2)

BEGIN
DECLARE PrductDiscValue DECIMAL(10, 2);
DECLARE DiscType INT(1);
DECLARE DiscValue DESIMAL(10,2);

IF ProductID != 0 THEN 
    SET PrductDiscValue = (SELECT Discountvalue, DiscountType FROM discount WHERE FIND_IN_SET(ProductID,DiscIDs);
END IF;

RETURN ProductDiscountValue(1);

但这不起作用。所以,我做以下

IF ProductID != 0 THEN 
    DECLARE PrductDiscValue CURSOR FOR SELECT Discountvalue, DiscountType FROM discount WHERE FIND_IN_SET(ProductID,DiscIDs;
END IF;

OPEN ProductDiscountValue;
FETCH ProductDiscountValue INTO DiscValue, DiscType; 
RETURN DiscValue;
END

这给了我错误::

1064 - 您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 16 行的“DECLARE ProdDiscValue CURSOR FOR SELECT Discountvalue, DiscountType FROM discount”附近使用正确的语法。

我需要 DiscValue 和 DiscType 进行不同的计算。

任何帮助将不胜感激

提前致谢。

4

2 回答 2

4

请使用它:

开始

IF test = true THEN
    BEGIN 
        DECLARE ats_cursor CURSOR FOR SELECT distinct ats_id FROM ats_eb ats where  ats.year = year and  ats.edition_shortname = edition;
    END;
ELSE
    BEGIN 
        DECLARE ats_cursor CURSOR FOR SELECT distinct ats_id FROM ats_eb ats where  ats.year = year and  ats.edition_shortname = edition;
    END;
END IF;

结尾

于 2021-05-23T07:32:35.113 回答
2

即使到目前为止我从未在 MySQL 中使用过 CURSOR,但我发现的是,它在MySQL 手册中明确提到

游标声明必须出现在处理程序声明之前以及变量和条件声明之后。

如果您想在某些条件下使用该游标,那么您必须在IF条件中使用FETCH CURSOR语法

下面是一些很好的教程,将详细描述光标:

mySQL 存储过程中的 CURSOR

MySQL CURSOR 教程

于 2013-06-07T05:48:06.123 回答