gpt4 book ai didi

sql - 迭代生成数值

转载 作者:行者123 更新时间:2023-12-04 06:29:17 26 4
gpt4 key购买 nike

我有一张表,我们称它为 Foo,表中有一个名为 Bar 的字段,还有一个名为 LoremIpsum 的字段。

Bar 是一个 nvarchar,但我只对可转换为整数的 Bar 值感兴趣。

LoremIpsum 也是一个数字。

我想从我的 Foo 表中获取以 k 开头的前 n 个(值)数字,其中 LoremIpsum 具有特定值(LoremIpsum1)和(值)不在来自 Foo 的选择栏中,其中 LoremIpsum = LoremIpsum1

我的输入是:(LoremIpsum1, n, k)

其中 LoremIpsum1 是 LoremIpsum 的特定值,n 是要获取的数字数量,k 是偏移量。

如果 LoremIpsum = LoremIpsum1,我的输出应该是一组不作为 Bar 值存在于表中的数字。我当前的命令:

WITH    q AS
(
SELECT convert(bigint, 50000) AS num
UNION ALL
SELECT convert(bigint, num + 1)
FROM q
)
SELECT top 200 *
FROM q
where convert(bigint, num) not in (select convert(bigint, Bar) from Foo where LoremIpsum = 68 and isnumeric(Bar + 'e0') = 1)
option (maxrecursion 365);

此查询并不总是有效,在计算机上,问题是 nvarchar 无法转换为 bigint,可能是设置有问题,如果所需的递归比给定的 maxrecursion 更深,则会发生另一个错误。

在这种情况下,n = 200,k = 50000,LoremIpsum1 = 68

主要问题是此查询是递归的,我想将其修改为迭代查询。

任何帮助是极大的赞赏。

此致,
拉霍斯·阿尔帕德。

最佳答案

您可以使用具有足够数字以满足您的需要的永久数字表,而不是递归 cte。

create table NumberTable(Num int primary key)

您可以使用递归 cte 来填充数字表。由于这只是一次性的事情,因此性能不应该那么重要,如果是的话,您可以看看 here .
WITH    q AS
(
SELECT 0 AS num
UNION ALL
SELECT num + 1
FROM q
)
insert into NumberTable(Num)
select top 10000 num
from q
option (maxrecursion 0)

在您的查询中使用带有偏移量的数字表。
declare @n int = 200
declare @k int = 50000

SELECT top (@n) num+@k
FROM NumberTable
--where convert(bigint, num+k) not in (select ...

关于sql - 迭代生成数值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5633392/

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