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();

 

 
posted @ 2019-11-02 10:34  VicLW  阅读(1374)  评论(0编辑  收藏  举报