gpt4 book ai didi

sql - 生成一个在sql server表中不存在的随机数

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

我正在寻找生成一个随机数,生成的数字不在另一个表上。

例如:如果一个表名为 randomNums具有值 10,20,30,40,50 .

除了上述值,我喜欢生成一个数字。

我尝试了以下查询。

查询

;WITH CTE AS
(
SELECT FLOOR(RAND()*100) AS rn
)
SELECT rn FROM CTE
WHERE rn NOT IN (SELECT num FROM randomNums);

但有时此查询不返回任何内容。
因为那个时候它生成了表中的数字 randomNums .

如何解决这个问题?

Fiddle for reference

最佳答案

另一种选择,我一直很喜欢NEWID()对于随机排序,交叉连接非常有效地创建许多行:

;with cte AS (SELECT 1 n UNION ALL SELECT 1)
,cte2 AS (SELECT TOP 100 ROW_NUMBER() OVER(ORDER BY a.n) n
FROM cte a,cte b,cte c,cte d, cte e, cte f, cte g)
SELECT TOP 1 n
FROM cte2 a
WHERE NOT EXISTS (SELECT 1
FROM randomNums b
WHERE a.n = b.num)
ORDER BY NEWID()

演示: SQL Fiddle

关于sql - 生成一个在sql server表中不存在的随机数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28500029/

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