【问题标题】:Multiple random values in SQL Server 2005SQL Server 2005 中的多个随机值
【发布时间】:2010-09-16 00:52:20
【问题描述】:

我需要在 SQL Server 2005 下生成多个随机值,但不知何故这根本行不通

with Random(Value) as
(
    select rand() Value
        union all
    select rand() from Random

)select top 10 * from Random

首选的解决方法是什么?

【问题讨论】:

  • 我喜欢这种迫使我去学习新东西的问题!谢谢!希望答案有所帮助。

标签: sql sql-server random


【解决方案1】:

你有没有尝试过这样的事情(在http://weblogs.sqlteam.com 找到):

CREATE VIEW vRandNumber
AS
SELECT RAND() as RandNumber
GO

创建一个函数

CREATE FUNCTION RandNumber()
RETURNS float
AS
  BEGIN
     RETURN (SELECT RandNumber FROM vRandNumber)
  END
GO

然后你可以像往常一样在你的选择中调用它 选择 dbo.RandNumber() , * from myTable

或来自他们的 cmets:

select RAND(CAST(NEWID() AS BINARY(6))), * from myTable

【讨论】:

  • 谢谢!似乎他们的 cmets 的解决方案与我经过一些修补后想出的相同。真的很奇怪,它没有得到重估。
【解决方案2】:

我目前正在使用这个:

with Random(Value) as
(
    select rand(checksum(newid())) Value
        union all
    select rand(checksum(newid())) from Random  
)select top 10 * from Random

但这似乎过于骇人听闻:S 为什么 rand 在第一个版本中没有得到重新评估?

【讨论】:

  • 这将具有与 newid() 一样多的熵。 checksum() 和 rand() 在这种情况下都是确定性的。
猜你喜欢
  • 1970-01-01
  • 2011-04-03
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-01-13
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多