SQLServer 使用rand获取随机数的操作

作者:Wikey_Zhang 时间:2024-01-24 00:22:11 

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()这个函数,提示报错如下:

SQLServer 使用rand获取随机数的操作

其实rand函数有个弊端,假设我们有一张表,存放的是1~10这些id,我们想把每个id都附上一个随机数,如下图:

SQLServer 使用rand获取随机数的操作

也许我么可以这样做:

SQLServer 使用rand获取随机数的操作

一眼就能看出这些随机数都是一样的,其实这并不是我们想要的结果。

如果换成是newid试试:

SQLServer 使用rand获取随机数的操作

这才叫随机嘛!

为什么会出现这样的结果?

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

来源:https://blog.csdn.net/Wikey_Zhang/article/details/76638981

标签:SQLServer,rand,随机数
0
投稿

猜你喜欢

  • 详解微信小程序「渲染层网络层错误」的解决方法

    2024-04-22 13:01:23
  • python批量复制图片到另一个文件夹

    2021-04-30 09:36:50
  • Go Grpc Gateway兼容HTTP协议文档自动生成网关

    2024-05-21 10:27:16
  • js实现鼠标感应向下滑动隐藏菜单的方法

    2024-05-02 17:23:21
  • Pycharm中安装pywin32报错问题及解决

    2022-09-29 19:58:14
  • 通过自学python能找到工作吗

    2021-07-24 04:26:33
  • Python面试题之统计哈希列表中最多元素

    2023-06-26 20:24:49
  • python后端接收前端回传的文件方法

    2023-07-29 04:04:05
  • Python中Enum使用的几点注意事项

    2021-08-19 11:19:03
  • Python实现判断给定列表是否有重复元素的方法

    2021-05-25 13:34:59
  • Python使用pylab库实现绘制直方图功能示例

    2022-12-07 04:48:56
  • Anaconda+Pycharm+Pytorch虚拟环境创建(各种包安装保姆级教学)

    2023-06-27 23:21:39
  • MySQL简化输入小技巧

    2024-01-13 15:49:33
  • Python实现一键改变raw格式照片风格

    2021-04-07 10:48:16
  • PHP PDOStatement::rowCount讲解

    2023-06-06 12:24:04
  • 对python中Json与object转化的方法详解

    2022-11-13 23:42:35
  • ASP实现文件直接下载

    2008-11-19 15:39:00
  • mysql 5.7.13 winx64安装配置方法图文教程

    2024-01-25 19:43:37
  • 怎样生成utf-8编码的html文件

    2009-03-11 19:34:00
  • pytorch 如何使用amp进行混合精度训练

    2023-12-25 13:35:02
  • asp之家 网络编程 m.aspxhome.com