SQLServer使用rand获得随机数
来源:互联网 发布:手机视频播放网页源码 编辑:程序博客网 时间:2024/05/29 12:22
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的用法后面再讲吧!今天啰嗦的有点多了~~
阅读全文
2 0
- SQLServer使用rand获得随机数
- SQLServer使用Checksum结合NewID获得随机数
- 使用rand获取随机数
- rand()随机数
- Rand 随机数
- 随机数Rand()
- rand随机数
- MySQL使用rand函数实现随机数[转]
- 关于rand使用及随机数再现问题
- 使用rand()与srand()产生随机数
- srand,rand随机数发生器函数的使用
- 使用rand函数产生伪随机数
- c语言随机数函数 rand()的使用
- MySQL使用rand函数实现随机数[转]
- 产生随机数 rand() 和 srand() 函数的使用
- C/C++使用rand()和srand()函数产生随机数
- c++ 生成随机数rand()函数的使用:设定范围
- 随机数函数srand和rand()的使用心得
- Channel Configuration(configtx)
- 级联分类器(Adaboost)之《多尺度尺寸的计算方法》
- CentOS添加磁盘分区
- 能源物联网技术笔试题
- 链表的K组翻转问题
- SQLServer使用rand获得随机数
- 微信小程序--使用微信官方demo解密userinfo加密数据
- C++继承与多态
- PHP字符串和数组转换
- Oracle-Sql规范
- ext id重复
- Maven+SSM框架下项目开发常见异常及解决方案(二)
- LeetCode 414 Third Maximum Number
- PHP字符串操作函数