SQL Server 从一组数字中随机获取一个数
很多人在开发需求中想获取一个随机数,或者从一组数字中获取一个数, 这个需求很简单,而且有很多方式可以实现,下面就介绍几种常见的方式,以作为笔记或供有需要的人参考.
比如有一组数字: 57 59 63 66 89 92 95,我们要从中随机取出一个:
方法一: 建表
--创建中间表存放随机数字 CREATE TABLE rand_number(id INT IDENTITY,num INT); INSERT INTO dbo.rand_number ( num )--57 59 63 66 89 92 95 VALUES ( 57 ),( 59 ),( 63 ),( 66 ),( 89 ),( 92 ),( 95 );
取随机数
SELECT num FROM dbo.rand_number WHERE id=ROUND(RAND()*6+1,0);
方法二: 不建表(CTE虚拟表)
;WITH temp_table AS( SELECT 1 id,57 num UNION ALL SELECT 2 id,59 num UNION ALL SELECT 3 id,63 num UNION ALL SELECT 4 id,66 num UNION ALL SELECT 5 id,89 num UNION ALL SELECT 6 id,92 num UNION ALL SELECT 7 id,95 num ) SELECT num FROM temp_table WHERE id=ROUND(RAND()*6+1,0);
方法三: 不建表 (派生表)
SELECT TOP 1 num FROM( SELECT 57 num UNION ALL SELECT 59 UNION ALL SELECT 63 UNION ALL SELECT 66 UNION ALL SELECT 89 UNION ALL SELECT 92 UNION ALL SELECT 95 )t ORDER BY NEWID();