在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
Rand()函数是系统自带的获取随机数的函数,可以直接运行select rand() 获取0~1之间的float型的数字。 如果想要获取0~100之间的整数随机数,可以这样使用 select round(100*rand(),0)。 为方便使用,下面延伸了一个方法:DECLARE @NumBegin Int=60 --随机数的最小值 DECLARE @NumEnd Int=100 --随机数的最大值 DECLARE @Decimal Int=2 --保留小数点几位 SELECT @NumBegin+round((@NumEnd-@NumBegin)*rand(),@Decimal) 这个方法通过传入最大值和最小值以及返回数保留几位小数,来获取对应的随机值。上面这个例子执行结果是获取60和100之间的随机数保留两位小数,如果将2改为-1,则变成获取60~100之间的10的倍数的整数,不信可以尝试一下! 注:这里本来想写成一个函数的,方便调用,可是事与愿违啊!函数居然不支持rand()这个函数,提示报错如下: 其实rand函数有个弊端,假设我们有一张表,存放的是1~10这些id,我们想把每个id都附上一个随机数,如下图: 也许我么可以这样做: 一眼就能看出这些随机数都是一样的,其实这并不是我们想要的结果。 如果换成是newid试试: 这才叫随机嘛! 为什么会出现这样的结果? 一样的sql语法,使用newid出来的结果是“真随机”,而用rand出来的结果却是“伪随机”。 而我们需要的是一串纯数字,用newid出来的结果并不方便处理。所以,针对这种情景,我们还有一个方式获得随机数,那就需要引入另外一个函数 checksum 了,checksum可以和newid结合使用产生随机数,关于checksum的用法后面再讲吧! 今天啰嗦的有点多了~~ 补充:Sqlserver中插入100内的随机整数---rand、newId()使用 update test set qty=cast( floor(rand()*100) as int); 插入的qty值都是一样的 函数说明: cast( floor(rand()*100) as int)
cast 是进行类型转换的, 可以针对各种数据类型. 修改的是用户的数据类型. 语法: CAST ( expression AS data_type ) update testdata set qty=abs(CHECKSUM(NEWID())%100+1) 插入的qty的值 是不一样的 关于随机取得表中任意N条记录的方法,很简单,就用newid():select top N * from table_name order by newid() ----N是一个你指定的整数,表示取得记录的条数 -----newid()在扫描每条记录的时候都生成一个值, 而生成的值是随机的, 没有大小写顺序 以上为个人经验,希望能给大家一个参考,也希望大家多多支持极客世界。如有错误或未考虑完全的地方,望不吝赐教。 |
请发表评论