zoukankan      html  css  js  c++  java
  • 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();
    
    
    
     
  • 相关阅读:
    leetcode167 Two Sum II
    leetcode18 4Sum
    leetcode15 three sum
    leetcode-1-Two Sum
    SQL优化——select
    Hadoop 集群搭建
    虚拟机中的两台主机怎么相互拷贝文件
    doker5
    docker4
    docker3
  • 原文地址:https://www.cnblogs.com/VicLiu/p/11780922.html
Copyright © 2011-2022 走看看