HSQLDB 2.3.3:我如何 return 一个序列的下一个值数组
HSQLDB 2.3.3: How do I return an array of next values for a sequence
我有一个存储过程 return 序列的下一个值,但我需要序列的下一个 "N" 值。我想传入 N 作为 NUMBEROFIDS 参数,见下文。那么 OUT GENERATEDID 将改为 ARRAY。这在 HSQLDB 中甚至可能吗?
CREATE PROCEDURE MY_PROCEDURE(
IN NUMBEROFIDS NUMERIC,
OUT GENERATEDID NUMERIC)
MODIFIES SQL DATA
BEGIN ATOMIC
SELECT NEXT VALUE FOR MY_SEQUENCE INTO GENERATEDID FROM MY_TABLE;
END;
您需要将参数声明为 ARRAY 并使用循环填充数组。
CREATE PROCEDURE MY_PROCEDURE(
IN NUMBEROFIDS INTEGER,
OUT GENERATEDID NUMERIC ARRAY)
BEGIN ATOMIC
DECLARE GENID NUMERIC ARRAY;
DECLARE COUNTER INTEGER DEFAULT 1;
WHILE COUNTER <= NUMBEROFIDS DO
SET GENID[COUNTER] = NEXT VALUE FOR MY_SEQUENCE;
END WHILE;
SET GENERATEDID = GENID;
END;
我有一个存储过程 return 序列的下一个值,但我需要序列的下一个 "N" 值。我想传入 N 作为 NUMBEROFIDS 参数,见下文。那么 OUT GENERATEDID 将改为 ARRAY。这在 HSQLDB 中甚至可能吗?
CREATE PROCEDURE MY_PROCEDURE(
IN NUMBEROFIDS NUMERIC,
OUT GENERATEDID NUMERIC)
MODIFIES SQL DATA
BEGIN ATOMIC
SELECT NEXT VALUE FOR MY_SEQUENCE INTO GENERATEDID FROM MY_TABLE;
END;
您需要将参数声明为 ARRAY 并使用循环填充数组。
CREATE PROCEDURE MY_PROCEDURE(
IN NUMBEROFIDS INTEGER,
OUT GENERATEDID NUMERIC ARRAY)
BEGIN ATOMIC
DECLARE GENID NUMERIC ARRAY;
DECLARE COUNTER INTEGER DEFAULT 1;
WHILE COUNTER <= NUMBEROFIDS DO
SET GENID[COUNTER] = NEXT VALUE FOR MY_SEQUENCE;
END WHILE;
SET GENERATEDID = GENID;
END;