ALTER PROCEDURE [dbo].[usp_RandomNumber]
(
@Len INT = 1, --随机数位数
@Rows INT = 1 --随机笔数
)
AS
BEGIN
DECLARE @T AS TABLE([Random Number] VARCHAR(MAX))
DECLARE @L INT = 1, @R INT = 1
WHILE @R <= @Rows
BEGIN
DECLARE @RN varchar(MAX) = ''
WHILE @L <= @Len --随机产生每个随数的位数
BEGIN
SET @RN = @RN + CHAR(ROUND(RAND() * 9 + 48,0))
SET @L = @L + 1
END
--如果产生相同的随机数,将不会存储
IF NOT EXISTS(SELECT [Random Number] FROM @T WHERE [Random Number] = @RN)
BEGIN
INSERT INTO @T SELECT @RN --INSERT INTO @T ([Random Number])VALUES (@RN)
SET @R = @R + 1 --记录总共产生了几笔随机数
SET @L = 1 -- 每产生完一个随机数之后,将随机数的位数初始化为1
END
END
Return @RN
END
调用:
EXECUTE [dbo].[usp_RandomNumber] 8,1
Sqlserver 不重复的随机数
MSSQL随机数
MSSQL有一个函数CHAR()
是将int(0-255)
ASCII
代码转换为字符。那我们可以使用下面MS SQL语句,可以随机生成小写、大写字母,特殊字符和数字。
大写字母:
CHAR(ROUND(RAND() * 25 + 65,0))
小写字母:
CHAR(ROUND(RAND() * 25 + 97,0))
特殊字符:
CHAR(ROUND(RAND() * 13 + 33,0))
数字:
CHAR(ROUND(RAND() * 9 + 48,0))
代码如下:
usp_RandomNumber
CREATE PROCEDURE [dbo].[usp_RandomNumber]
(
@Len INT = 1, --随机数位数
@Rows INT = 1 --随机笔数
)
AS
BEGIN
DECLARE @T AS TABLE([Random Number] VARCHAR(MAX))
DECLARE @L INT = 1, @R INT = 1
WHILE @R <= @Rows
BEGIN
DECLARE @RN varchar(MAX) = ''
WHILE @L <= @Len --随机产生每个随数的位数
BEGIN
SET @RN = @RN + CHAR(ROUND(RAND() * 9 + 48,0))
SET @L = @L + 1
END
--如果产生相同的随机数,将不会存储
IF NOT EXISTS(SELECT [Random Number] FROM @T WHERE [Random Number] = @RN)
BEGIN
INSERT INTO @T SELECT @RN --INSERT INTO @T ([Random Number])VALUES (@RN)
SET @R = @R + 1 --记录总共产生了几笔随机数
SET @L = 1 -- 每产生完一个随机数之后,将随机数的位数初始化为1
END
END
SELECT [Random Number] FROM @T
END
当你把上面的存储过程附加入数据库之后,可以执行这个存储过程:
代码如下:
EXECUTE [dbo].[usp_RandomNumber] 8,10
得到的结果(由于是随机产生,每次execute
获得结果会不一样)
SQLserver随机数函数
随机函数:rand()
在查询分析器中执行:select rand()
,可以看到结果会是类似于这样的随机小数:0.36361513486289558
,
像这样的小数在实际应用中用得不多,一般要取随机数都会取随机整数。那就看下面的两种随机取整数的方法:
1、
A:
select floor(rand()*N) ---生成的数是这样的:12.0
B:
select cast( floor(rand()*N) as int) ---生成的数是这样的:12
2、
A:
select ceiling(rand() * N) ---生成的数是这样的:12.0
B:
select cast(ceiling(rand() * N) as int) ---生成的数是这样的:12
其中里面的N
是一个你指定的整数,如100
,可以看出,两种方法的A
方法是带有.0这个的小数的,而B方法就是真正的整数了。
大致一看,这两种方法没什么区别,真的没区别?其实是有一点的,那就是他们的生成随机数的范围:
方法1的数字范围:0
至N-1
之间,如cast( floor(rand()*100) as int)
就会生成0至99之间任一整数
方法2的数字范围:1
至N
之间,如cast(ceiling(rand() * 100) as int)
就会生成1至100之间任一整数
对于这个区别,看SQL的联机帮助就知了:
比较 CEILING
和 FLOOR
CEILING
函数返回大于或等于所给数字表达式的最小整数。FLOOR
函数返回小于或等于所给数字表达式的最大整数。例如,对于数字表达式 12.9273
,CEILING
将返回 13
,FLOOR
将返回 12
。FLOOR
和 CEILING
返回值的数据类型都与输入的数字表达式的数据类型相同。
现在,各位就可以根据自己需要使用这两种方法来取得随机数了_
另外,还要提示一下各位菜鸟,关于随机取得表中任意N条记录的方法,很简单,就用newid()
:
select top N * from table_name order by newid() ----N是一个你指定的整数,表是取得记录的条数
sqlserver产生随机数
方法1的数字范围:0至N-1之间,如cast(floor(rand()*100) as int)
就会生成0至99之间任一整数
方法2的数字范围:1至N之间,如cast(ceiling(rand() * 100) as int)
就会生成1至100之间任一整数
另外,还要提示一下各位菜鸟,关于随机取得表中任意N条记录的方法,很简单,就用newid()
:
select top N * from table_name order by newid() ----N是一个你指定的整数,表是取得记录的条数