【发布时间】:2020-09-08 13:51:43
【问题描述】:
在 SQL Server 中,您可以像这样从序列中选择下一个值:
select next value for MY_SEQ
如果您不禁止选择要从中选择的表,则对于每一行都会输出下一个值:
select next value for MY_SEQ
from MY_TABLE
[2020-09-08 15:47:34] 350 rows retrieved starting from 1 in 102 ms (execution: 62 ms, fetching: 40 ms)
如何为序列选择下一个 n 值?
在 Oracle 中,这看起来像这样:
select MY_SEQ.nextval
from (
select level
from dual
connect by level < 10
)
我尝试过这样的事情:
select top(10) next value for MY_SEQ
但结果是:
[S0001][11739] 如果设置了 ROWCOUNT 选项,或者查询包含 TOP 或 OFFSET,则无法使用 NEXT VALUE FOR 函数。
我想我可以创建一个包含 n 行的临时表并从中进行选择,但这不是一个特别优雅的解决方案。
【问题讨论】:
标签: sql sql-server tsql-sequence