sql怎么取随机数(SQLServer 使用rand获取随机数的操作)
sql怎么取随机数
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()在扫描每条记录的时候都生成一个值, 而生成的值是随机的, 没有大小写顺序
以上为个人经验,希望能给大家一个参考,也希望大家多多支持开心学习网。如有错误或未考虑完全的地方,望不吝赐教。
- sqlserver常见函数(SQL Server之JSON 函数详解)
- sqlserver查看表和存储过程的架构(SQL Server 远程更新目标表数据的存储过程)
- sqlserverselect选择两个参数(SQL SERVER中SELECT和SET赋值相同点与不同点推荐)
- SqlServer类似正则表达式的字符处理问题(SqlServer类似正则表达式的字符处理问题)
- sqlserver仲裁状态(使用 SQL 服务器时,"评估期已过期"错误消息解决方法)
- sqlserver新建连接服务器卡住(SQL Server成功与服务器建立连接但是在登录过程中发生错误的快速解决方案)
- sqlserver数据库的对象有哪些(详解SQL Server数据库架构和对象、定义数据完整性)
- sql server导入数据csv文件(大容量csv快速内导入sqlserver的解决方法推荐)
- sqlserver乐观锁与悲观锁(sql server中死锁排查的全过程分享)
- sqlserver限制windows身份登录(解决sql server 数据库,sa用户被锁定的问题)
- microsoftsqlserver官网(Microsoft SQL Server数据库各版本下载地址集合)
- SQLServer中防止并发插入重复数据的方法详解(SQLServer中防止并发插入重复数据的方法详解)
- sqlserver存储过程怎么写日志(SqlServer快速检索某个字段在哪些存储过程中sql 语句)
- sqlserver数据库技术及应用教程(SQLServer2019 数据库的基本使用之图形化界面操作的实现)
- sqlserver表分区缺点(SQL Server 公用表表达式CTE实现递归的方法)
- sqlserver 开启数据库(SQLSERVER简单创建DBLINK操作远程服务器数据库的方法)
- 苏志燮赵恩静结婚,韩国四大公共财产变三人,这么快就有替补了(苏志燮赵恩静结婚)
- 《内在美》后,一大波新韩剧来袭,李钟硕朴信惠宋慧乔玄彬回归(一大波新韩剧来袭)
- 给孩子选购保温杯,注意这4个步骤,比颜值更重要(给孩子选购保温杯)
- 保温好 容量大 颜值高 保温杯你给娃娃买对了吗(保温好容量大颜值高)
- 《道德经》 人生避开骄狂,才能免去祸患(道德经人生避开骄狂)
- 郭麒麟(郭麒麟)
热门推荐
- cdn上传加速(云服务器搭建网站需要用CDN加速吗?)
- html5中怎么做圆形框架(HTML5 层的叠加的实现)
- docker jdk离线安装(docker安装openjdk并运行jar包的操作方法)
- php用什么解压(php解压缩zip和rar压缩包文件的方法)
- php在if里添加xml代码(PHP创建XML接口示例)
- dedecms添加代码(dedecms内容页调用栏目链接和栏目名称的方法)
- php怎么实现邮件发送(使用php的mail函数实现发送邮件功能)
- python实现删除列表重复元素功能(Python实现删除排序数组中重复项的两种方法示例)
- css3设置元素的边框图像(详解CSS3 用border写 空心三角箭头 两种写法)
- 如何用tomcat部署web项目(一文搞懂如何部署启动多个tomcat并移植项目)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9