博客
关于我
sql 两个数字范围取随机数
阅读量:572 次
发布时间:2019-03-10

本文共 821 字,大约阅读时间需要 2 分钟。

常用到通过两个数字之间获取随机数,C#中有内置方法,数据库中没有。以前有找到过一个方法,是通过数据库自定义函数实现,但是找不到了,今天自己写了个,记录下来备用!

 

代码如下:

if 
exists(
select 
* 
from sys.objects 
where name 
= 
'
f_random
')
    
drop 
function f_random
go
/*
两个数之间获取随机数
*/
create 
function f_random
(
    
@min_num 
int,
    
@max_num 
int
)
returns 
int
as
begin
    
declare 
@basicnumber 
decimal(
18,
9)    
--
基数
    
declare 
@randnumber 
decimal(
18,
9
--
随机数
    
if 
@max_num 
<= 
10
        
set 
@basicnumber 
= 
10
    
else 
if 
@max_num 
<= 
100
        
set 
@basicnumber 
= 
100
    
else 
if 
@max_num 
<= 
1000
        
set 
@basicnumber 
= 
1000
    
else 
if 
@max_num 
<= 
10000
        
set 
@basicnumber 
= 
10000
    
while 
1 
= 
1
    
begin
        
select 
@randnumber 
= randvalue 
from vRandom
        
set 
@randnumber 
= 
@randnumber 
* 
@basicnumber
        
if 
@randnumber 
>= 
@min_num 
and 
@randnumber 
< 
@max_num
            
break
        
else
            
continue
    
end
    
return 
cast(
@randnumber 
as 
int)
end
go

使用方法:

select dbo.f_random(1,100) as randnum    

一定要加dbo!

 

 

转载地址:http://nqzvz.baihongyu.com/

你可能感兴趣的文章
nacos服务注册流程
查看>>
Nacos服务部署安装
查看>>
nacos本地可以,上服务器报错
查看>>
Nacos注册中心有几种调用方式?
查看>>
nacos注册失败,Feign调用失败,feign无法注入成我们的bean对象
查看>>
nacos源码 nacos注册中心1.4.x 源码 nacos源码如何下载 nacos 客户端源码下载地址 nacos discovery下载地址(一)
查看>>
Nacos简介、下载与配置持久化到Mysql
查看>>
Nacos简介和控制台服务安装
查看>>
Nacos管理界面详细介绍
查看>>
Nacos编译报错NacosException: endpoint is blank
查看>>
nacos自动刷新配置
查看>>
nacos运行报错问题之一
查看>>
Nacos部署中的一些常见问题汇总
查看>>
NACOS部署,微服务框架之NACOS-单机、集群方式部署
查看>>
Nacos配置Mysql数据库
查看>>
Nacos配置中心中配置文件的创建、微服务读取nacos配置中心
查看>>
Nacos配置中心集群原理及源码分析
查看>>
nacos配置在代码中如何引用
查看>>
nacos配置新增不成功
查看>>
nacos配置自动刷新源码解析
查看>>