sql中rand函数用法是什么?怎样获取随机数?
Admin 2022-03-23 群英技术资讯 5048 次浏览
这篇文章给大家分享的是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()这个函数,提示报错如下:
其实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)
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函数使用可以关注其他文章。
相关阅读:
sql server触发器有哪些类型,如何创建?
sql语句group by怎样使用?一文带你搞懂
sql替换语句怎样做批量数据管理操作?
sql的存储过程定义有哪些方法,你知道几种?
SQL的JOIN类型有哪些?有何不同?
SQL数据操作语句你了解多少?
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章给大家分享的是有关sql server 调用dll文件的内容,下文有具体的调用过程,对新手学习sql server有一定的参考借鉴价值,感兴趣的朋友就继续往下看吧。
mssql与mysql的有什么区别?哪个更好用?MySQL可以说是MSSQL的简化版本。理念相同,但MySQL的实现比MSSQL的需求低。MySQL是一个免费的、开放源代码的SQL数据库,所以免费的MYSQL很受欢迎,php+mysql,MySQL数据库专用于PHP网站的,一般用在PHP的网页上的,他和PHP可以说是黄金搭档(都是开源免费的东西)。
这篇文章介绍了SQL Server创建用户定义函数的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
这篇文章给大家分享的是有关SQL Server分隔函数怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,接下来就跟随小编一起来学习吧。
这篇文章主要介绍了SQL行转列和列转行代码详解,涉及动态方案和静态方案两种处理方式,具有一定参考价值,需要的朋友可以了解下。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008