加入收藏 | 设为首页 | 会员中心 | 我要投稿 银川站长网 (https://www.0951zz.com/)- 云通信、基础存储、云上网络、机器学习、视觉智能!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql中rand函数用法是什么 怎样取得随机数

发布时间:2023-06-12 11:14:52 所属栏目:MsSql教程 来源:
导读: 这篇文章给大家分享的是SQLServer中Rand()函数的使用,主要介绍Rand()函数如何获取随机数,文本有实现过程及代码,有这方面学习需要的朋友可以参考参考。 Rand()函数是系统自带的获取随机数的函数,可以直接运

    这篇文章给大家分享的是SQLServer中Rand()函数的使用,主要介绍Rand()函数如何获取随机数,文本有实现过程及代码,有这方面学习需要的朋友可以参考参考。

    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函数有个弊端,假设我们有一张表,存放的是1~10这些id,我们想把每个id都附上一个随机数。

    这才叫随机嘛!为什么会出现这样的结果?

    一样的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)

    FLOOR(n)函数:取小于等于数值n的最大整数

    rand:这种用法没有参数,会返回一个具有38位精度的数值,范围从0.0到1.0,但不包括1.0

    *N :N指定为整数,通过设置N值来设定 随机数的取值范围

    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()在扫描每条记录的时候都生成一个值, 而生成的值是随机的, 没有大小写顺序

    以上就是关于sqlserver中rand函数获取随机数的操作介绍,rand函数小编认为还是比较实用的,因此大家一定要掌握rand函数的用法,希望本文对大家学习有帮助,更多rand函数使用可以关注其他文章。

(编辑:银川站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章