gpt4 book ai didi

sql - 有没有一种通用的方法可以在 SQL 中生成任意线性序列?

转载 作者:行者123 更新时间:2023-12-04 18:53:04 25 4
gpt4 key购买 nike

是否有我可以执行的 SQL 查询将生成一个线性序列,例如

1, 2, 3, 4, 5, 6, 7 ... x+1

或者
2, 7, 12, 17, 22 ... 2+5x

(其中每个数字都是结果表的一行中的一个条目)

最佳答案

SQL Server 和 Oracle 现在实现了 ANSI 标准 ROW_NUMBER() 窗口函数,但您需要一个表来处理:

SELECT ROW_NUMBER() OVER (ORDER BY ID) AS __ROW, ID, Name
FROM SomethingWithANameAndAnID
ORDER BY __ROW;

或者您可以在 SQL Server 中使用递归公用表表达式(不确定 Oracle 是否实现了这一点):
WITH cte AS
(
SELECT 1 AS num
UNION ALL
SELECT (num + 1) AS num FROM cte
WHERE num < @SomeMaximum
)
SELECT * FROM cte OPTION (MAXRECURSION 0);

请注意,如果没有 MAXRECURSION 选项,MS SQL 中的 CTE 递归深度限制为 100。(值为 0 禁用递归限制)

关于sql - 有没有一种通用的方法可以在 SQL 中生成任意线性序列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3236452/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com