如何在Firebird select语句中创建1到100的范围?
我已经找到了将字符串转换为列表的方法,但它对我不起作用,因为我需要生成更大的范围How to input an array parameter of values to Firebird Stored Procedure?。
是否可以在不创建存储过程的情况下执行此类操作?
答案 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;