HSQLDB 2.3.3:如何为序列返回下一个值的数组

Posted

技术标签:

【中文标题】HSQLDB 2.3.3:如何为序列返回下一个值的数组【英文标题】:HSQLDB 2.3.3: How do I return an array of next values for a sequence 【发布时间】:2015-12-03 19:11:24 【问题描述】:

我有一个存储过程来返回序列的下一个值,但我需要序列的下一个“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;

【问题讨论】:

【参考方案1】:

您需要将参数声明为 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;

【讨论】:

以上是关于HSQLDB 2.3.3:如何为序列返回下一个值的数组的主要内容,如果未能解决你的问题,请参考以下文章

如何为 Hibernate 设置 HSQLDB?

C#中如何为一个有返回值的函数添加新线程

Oracle:如何为“SELECT * FROM tab WHERE name IN (function())”创建返回值的函数

如何为 where 子句中的列编写具有不连续值的 Cassandra 查询

基于文件的 HSQLDB 不跟踪序列上的调用下一个值

如何为序列项目训练 LSTM 模型?