如何在Firebird select语句中创建1到100的范围?

时间:2017-03-12 17:38:20

标签: sql firebird firebird2.5

如何在Firebird select语句中创建1到100的范围?

我已经找到了将字符串转换为列表的方法,但它对我不起作用,因为我需要生成更大的范围How to input an array parameter of values to Firebird Stored Procedure?

是否可以在不创建存储过程的情况下执行此类操作?

2 个答案:

答案 0 :(得分:6)

除了Gordon的建议外,您还可以使用可选择的存储过程来实现此目的:

create procedure generate_range(startvalue integer, endvalue integer)
    returns (outputvalue integer)
as
begin
    outputvalue = startvalue;
    suspend;

    while (outputvalue < endvalue) do
    begin
        outputvalue = outputvalue + 1;
        suspend;
    end
end

然后您可以将其用作:

select outputvalue from generate_range(1, 100);

如Gordon所示,CTE的优势在于它允许更大的范围,因为Firebird CTE的递归限制为1024.

答案 1 :(得分:5)

一种方法是递归CTE:

with recursive n as (
      select 1 as n
      from rdb$database
      union all
      select n.n + 1
      from n
      where n < 100
     )
select n.n
from n;