将字符串值设置为标量变量 HSQLDB



我尝试过如下;

CREATE PROCEDURE GetHs(IN FRVDate TIMESTAMP, IN TRVDate TIMESTAMP, IN RESValue NUMERIC(19,2),
RangeType VARCHAR(20), HRID VARCHAR(36)) 
READS SQL DATA
    DYNAMIC RESULT SETS 1
        BEGIN ATOMIC
            DECLARE TABLE myList(MValue NUMERIC(19,2), Price NUMERIC(19,2), FRVDate TIMESTAMP,TRVDate TIMESTAMP);
            DECLARE Counter INT;
            DECLARE dateDifference NUMERIC(19,2);
            DECLARE for_day,for_week VARCHAR(20);
            SET for_day = 'DAY';
            SET for_week = 'WEEK';
                IF RangeType = for_day THEN
                    BEGIN ATOMIC
                     ----statements----
                    END
                    ELSEIF RangeType = for_week THEN
                    BEGIN ATOMIC
                     ----statements----
                    END
                END IF
                SELECT MValue,Price,FRVDate,TRVDate FROM myList
        END

我得到的错误user lacks privilege or object not found: DAY.我不能将值设置为声明的标量变量吗?

在文档中,它说要以这种格式使用。来自文档;

BEGIN ATOMIC
 DECLARE temp_zero DATE;
 DECLARE temp_one, temp_two INTEGER DEFAULT 2;
 DECLARE temp_three VARCHAR(20) DEFAULT 'no name';
 -- more statements ...
 SET temp_zero = DATE '2010-03-18';
 SET temp_two = 5;
 -- more statements ...
END

我在这里做错了什么?

注意:最近开始使用 HSQL 并使用版本 2.3.3

此问题已在最新的 HSQLDB 代码中修复。下一个版本 2.4.0 支持它。下一版本的快照目前可在 http://hsqldb.org/support

最新更新