SELECT TOP 10 *,
       rand(ROUND(rand()*10000,0)+ROW_NUMBER() OVER(ORDER BY 1) --用相同的随机数加上不同的行号做种子
           ) random
  FROM tableA

解决方案 »

  1.   

    我觉得加点辅助的东西SELECT RAND(ASCII(LEFT(NEWID(),1)))
      

  2.   

    注:ORDER BY 1 换成任意的字段。
    行号和返回次序不同没关系。
      

  3.   

    declare   @maxNumber   int,   --随机数最大值 
       @minNumber   int,   --随机数最小值 
                      @rows   int               --要取得的行数   
    select   @maxNumber=10000, @minNumber=10000, 
                    @rows=10   
        
    set   rowcount   @rows   
        
    select   distinct   '1234 4567 '+convert(varchar,ID)+' '+convert(varchar,ID)+' '+convert(varchar,ID)+' '+convert(varchar,ID)   as   'B'   
    from   (    
                    select   convert(int,rand(checksum(newid()))*@minNumber)   as   ID   
                    from   syscolumns,sysobjects   
                )t   
        
    set   rowcount   0 
    -----------------------------------------------------------------------
    declare     @num1     int ,@num2     int ,@num3     int ,@num4     int   
    set @num1=rand(abs(convert(int,checksum(newid()))))*10000
    set @num2=rand(abs(convert(int,checksum(newid()))))*10000
    set @num3=rand(abs(convert(int,checksum(newid()))))*10000
    set @num4=rand(abs(convert(int,checksum(newid()))))*10000   
    select   convert(varchar(100),@num1)+' '+convert(varchar(100),@num2)+' '+convert(varchar(100),@num3)+' '+convert(varchar(100),@num4)
    ---------------------------------------------------------------------------
    declare @r1 numeric (15,0),@r2 numeric (15,0)
    SELECT @r1=RAND( (DATEPART(mm, GETDATE()) * 100000 )
               + (DATEPART(ss, GETDATE()) * 1000 )
               + DATEPART(ms, GETDATE()) )*10000
    print @r1