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登录时登录名下拉列表框中的选项)
- SQLServer中使用扩展事件获取Session级别的等待信息及SQLServer 2016中Session级别等待(SQLServer中使用扩展事件获取Session级别的等待信息及SQLServer 2016中Session级别等待)
- sqlserver存储删除过程(Sql中存储过程的定义、修改和删除操作)
- sqlserver限制windows身份登录(解决sql server 数据库,sa用户被锁定的问题)
- 查sqlserver锁表语句(Sql Server如何查看被锁的表及解锁的方法)
- sqlserver数据库备份怎么还原(SQL Server2012数据库备份和还原的教程)
- sqlserver安装日志文件夹(SQL SERVER日志进行收缩的图文教程)
- 2021-10-24 10:26:05
- sqlserver 怎么排序(SQLserver排序规则基本概念探索)
- sqlserver语句显示表字段(SQL Server查找表名或列名中包含空格的表和列实例代码)
- SQLServer将数据导出为SQL脚本
- sqlserver判断null(SQL Server索引超出了数组界限的解决方案)
- sqlserver2019使用教程图文(SQLServer2019 数据库环境搭建与使用的实现)
- sql server 进阶(SqlServer AS的用法)
- sqlserver删除表的第一行数据(sql server删除前1000行数据的方法实例)
- SQLserver中cube:多维数据集实例详解(SQLserver中cube:多维数据集实例详解)
- 《精英律师》剧照首曝光,实力演员飙戏,演绎律政职场百态(精英律师剧照首曝光)
- 靳东领衔打造高精职场 新丽出品《精英律师》曝定妆照(靳东领衔打造高精职场)
- 靳东新剧《精英律师》定档,众星云集,这剧可追(靳东新剧精英律师定档)
- 精英律师 廖佳敏封印恋情曝光,顾婕马失前蹄 你个老不死的(廖佳敏封印恋情曝光)
- 以家人之名广受好评,剧情生动引起观众共鸣,演员张新成圈粉无数(以家人之名广受好评)
- 三兄妹感情再遇波折,人设接连崩塌 《以家人之名》剧情猜不透(三兄妹感情再遇波折)
热门推荐
- JavaScript脚本数据类型
- mysql拼接多字段作为查询条件(Mysql 实现字段拼接的三个函数)
- laravel 数据表格(Laravel自定义 封装便捷返回Json数据格式的引用方法)
- zabbix 数据库优化(快速通过zabbix获取数据库连接的信息及部分扩展)
- mysql exists的用法(Mysql exists用法小结)
- SQL Server唯一约束
- laravel提取数据库的字段(Laravel创建数据库表结构的例子)
- python scrapy爬虫教程视频(详解python3 + Scrapy爬虫学习之创建项目)
- django表单提交到数据库(Django 表单模型选择框如何使用分组)
- dedecms操作方法(织梦Dedecms在循环列表中获取会员信息的方法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9