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

 更新时间:2021年01月14日 10:08:47   作者:Wikey_Zhang  
这篇文章主要介绍了SQLServer 使用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()在扫描每条记录的时候都生成一个值, 而生成的值是随机的, 没有大小写顺序

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

相关文章

  • SQL Server 2017无法连接到服务器的问题解决

    SQL Server 2017无法连接到服务器的问题解决

    本文主要介绍了SQL Server 2017无法连接到服务器的问题解决,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • SQL批量插入数据几种方案的性能详细对比

    SQL批量插入数据几种方案的性能详细对比

    昨天下午快下班的时候,无意中听到公司两位同事在探讨批量向数据库插入数据的性能优化问题,顿时来了兴趣,把自己的想法向两位同事说了一下,于是有了本文。
    2010-03-03
  • sql 2000清空后让表的id从1开始等数据库操作

    sql 2000清空后让表的id从1开始等数据库操作

    近来发现数据库过大,空间不足,因此打算将数据库的数据进行全面的清理,但表非常多,一张一张的清空,实在麻烦,因此就想利用SQL语句一次清空所有数据.找到了三种方法进行清空
    2012-12-12
  • Sql server连接Oracle数据库完整图文教程

    Sql server连接Oracle数据库完整图文教程

    又一次在项目中用到了在SQLServer添加Oracle链接服务器,索性这里总结下,这篇文章主要给大家介绍了关于Sql server连接Oracle数据库的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2024-01-01
  • SQL Server修改数据的几种语句详解

    SQL Server修改数据的几种语句详解

    在SQL中的基本操作就是增删改查,查询语句不会对数据库中的数据进行修改,下面这篇文章主要给大家介绍了关于SQL Server修改数据的几种语句,需要的朋友可以参考下
    2022-10-10
  • Sql Server触发器的使用

    Sql Server触发器的使用

    触发器是一种特殊的存储过程,不能被显式调用,只能在对表进行insert、update、delete操作时被自动激活。所以触发器可以用来实现对表进行复杂的完整性约束
    2012-12-12
  • SQL Server中T-SQL 数据类型转换详解

    SQL Server中T-SQL 数据类型转换详解

    T-SQL提供了两个显示转换的函数:CAST函数和CONVERT函数。今天我们就来相信探讨下
    2018-02-02
  • SQL Server的复制功能

    SQL Server的复制功能

    SQL Server的复制功能微软本身主要是用来发布及共享报表的。
    2009-05-05
  • sqlserver数据库加密后无法使用MDF,LDF,log文件名称被修改的数据恢复

    sqlserver数据库加密后无法使用MDF,LDF,log文件名称被修改的数据恢复

    这篇文章主要给大家分享的是sqlserver数据库加密后无法使用MDF,LDF,log文件名称被修改的数据恢复案例,如果工作中你也遇到这样的问题,可以参考一下
    2022-03-03
  • SQL server内存问题排查方案

    SQL server内存问题排查方案

    由于昨晚线上服务器数据库突然访问数据缓慢,任务管理里面SQL server进程爆满等等,重大事故的排查拟写解决方案,文中通过代码示例和图文讲解的非常详细,需要的朋友可以参考下
    2024-03-03

最新评论