RAND([seed])Returns pseudo-random FLOAT type value between 0 and 1. Example:SELECT RAND(.4)

解决方案 »

  1.   

    sorry my answer is wrong
      

  2.   

    不确定函数,NEWID() GETDATE() RAND()都不能在函数中使用。这是系统规定。
      

  3.   

    函数的确定性和副作用
    函数可以是确定的或不确定的。如果任何时候用一组特定的输入值调用函数时返回的结果总是相同的,则这些函数为确定的。如果每次调用函数时即使用的是相同的一组特定输入值,返回的结果总是不同的,则这些函数为不确定的。不确定的函数会产生副作用。副作用是更改数据库的某些全局状态,比如更新数据库表或某些外部资源,如文件或网络等(例如,修改文件或发送电子邮件消息)。不允许在用户定义函数主体中内置不确定函数;这些不确定函数如下:@@CONNECTIONS @@TOTAL_ERRORS 
    @@CPU_BUSY @@TOTAL_READ 
    @@IDLE @@TOTAL_WRITE 
    @@IO_BUSY GETDATE 
    @@MAX_CONNECTIONS GETUTCDATE 
    @@PACK_RECEIVED NEWID 
    @@PACK_SENT RAND 
    @@PACKET_ERRORS TEXTPTR 
    @@TIMETICKS   
    尽管在用户定义函数主体中不允许有不确定函数,这些用户定义函数在调用扩展存储过程时仍会产生副作用。由于扩展存储过程会对数据库产生副作用,因此调用扩展存储过程的函数是不确定的。当用户定义函数调用会对数据库产生副作用的扩展存储过程时,不要指望结果集保持一致或执行函数。 
      

  4.   

    你可以用视图代替它:
    create view view1 as
    select rand() as randvalue
    CREATE function funcMakeRandString()
    returns char(8)
    as 
    begin
    declare @sz varchar(8)
    declare @i int

    set @sz=''
    set @i=0
    while @i<8
    begin
    select @sz=@sz + convert(char(1),convert(int,(9*(select randvalue from view1)+1)))
    select @i=@i+1
    end
    return @sz
    end
      

  5.   

    select dbo.funcMakeRandString()
    73959638
      

  6.   

    自定义函数中不可以用“不确定函数”但是可以调用“不确定函数”!
    这样的函数还有好多,如@@ERROR,GETDATE等等!
      

  7.   

    函数存在的限制:
    不确定函数是不相同的输入条件下每次都返回不同的值!
    如:@@error,@@identity,@@rowcount,indet_incr,ident_seed,datename,newid,
    等等!
    但是我们可以调用它!
    如:
    use northwind
    go
    create proc aa(@indate datetime,
    @separator char(1))
    return nchar(20)
    as 
    begin 
    convert(nvarchar(20),datepart(mm,@indate))
    +@searator
    +convert(nvarchar(20),datepart(dd,@indate))
    +@searator
    +convert(nvarchar(20),datepart(yy,@indate))
    +@searator
    end语句好像有点错误:)