SQLSever: 怎样在select中的每一行产生不同的随机数?
2017-06-07 18:06
176 查看
select 的随机函数有点假, 或许是由于它是基于时间来的吧, 同一select中由于时间无法错开导致产生的随机数都是一样的。 怎样做到让不同的行拥有不同的随机数呢?
以下以产生某个月的随机日期来演示样例吧。
以下以产生某个月的随机日期来演示样例吧。
--创建最小为1 最大为31 的视图 if object_id('view_rand_int31') is not null begin drop view view_rand_int31 end go create view view_rand_int31 as select cast(ceiling(rand() * 31) as int) as [r] go --创建日期(天)的随机函数 if object_id('dbo.Fun_GetRandDay') is not null begin drop function dbo.Fun_GetRandDay end go CREATE FUNCTION dbo.Fun_GetRandDay ( @max INT ) returns int as begin declare @r int select @r = [r] from view_rand_int31 while @r>@max begin select @r = [r] from view_rand_int31 if @r<=@max begin break; end end return @r end go --试验select条件下实现多条记录同一时候取随机数 --插入试验数据行 declare @t table(rowNum int identity, [yearMonth] nvarchar(20)) declare @i int,@imax int select @i=1,@imax =28 while @i<=@imax begin insert into @t ([yearMonth]) select '2014年2月' set @i=@i+1 end --运行查询 select *, cast( '2014-02-' + cast( dbo.Fun_GetRandDay(28) as varchar(2)) as datetime) as [date], (select cast(ceiling(rand() * 28) as int)) as [r] from @t
相关文章推荐
- SQLSever: 如何在select中的每一行产生不同的随机数?
- SQLSever: 如何在select中的每一行产生不同的随机数?
- 趣见:java中同时产生两个不同的随机数
- [技巧]go语言使用select{}产生随机数
- rand()和srand((unsigned)time(NULL))产生的随机数有什么不同
- 总结:关于如何产生几个不同随机数的问题(C/C++)
- 怎样产生不重复的随机数,密码
- PHP 小技巧之(2)怎样的产生各不相同的随机数
- C语言/C++中怎样产生随机数
- SQLSever 使用游标为每一行数据赋值随机数
- C语言/C++中怎样产生随机数
- 如何用c++产生1-10十个不同的随机数(代码很经典)
- 给每一行数据更新一个不同的随机数
- 怎样产生标准分布或高斯分布的随机数?
- C语言/C++中怎样产生随机数
- C语言/C++中怎样产生随机数
- 随机产生13个0~51不同的随机数 -思想(定义参考系)
- C/C++怎样产生任意指定范围的随机数?
- 用PHP实现同时产生多个不同的随机数
- 怎样产生标准分布或高斯分布的随机数