SQLServer中 Checksum、 NewID、Rand函数使用(实例:每行随机数不一样)

Rand(): 此函数生成从0到1之间随机  float  值 
newid():此函数生成 uniqueidentifier 类型的唯一值

Checksum:总和检验码,校验和。 在SQLServer中Checksum()需要传入1个参数,可以是任何类型,如下示例:
[sql]  view plain  copy
  1. SELECT CHECKSUM(1)          --1  
  2. SELECT CHECKSUM('A')        --114  
  3. SELECT CHECKSUM('AA')       --34472462  
  4. SELECT CHECKSUM(GETDATE())  --18516390  

下面有一张临时表,只有id一个字段,我用checksum和rand两种方法分别给每个id附上一个随机数:
看出问题所在了吧!  使用newid出来的结果是“真随机”,而用rand出来的结果却是“伪随机”

下面延伸一个方法,供将来有需要获得随机数的时候使用!新建一个标量值函数,通过传入参数最大值、最小值、保留几位小数、以及newid()来获得随机数:
[sql]

CREATE FUNCTION Scalar_CheckSumNEWID
    (
      @MaxNum INT ,
      @MinNum INT ,
      @Keep INT ,
      @newid VARCHAR(50)
    )
RETURNS FLOAT
    BEGIN  
        DECLARE @ResultVar FLOAT  
        SELECT  @ResultVar = CONVERT(BIGINT, RIGHT(ABS(CHECKSUM(@newid)), 9))
                * 0.1 / 100000000  
        RETURN @MinNum +ROUND((@MaxNum -@MinNum )*@ResultVar,@Keep)  
    END  

注:newid之所以要放在传入参数中,是因为想newid和rand之类的不能放在函数的本身执行,只能通过传入参数带入

猜你喜欢

转载自blog.csdn.net/hezheqiang/article/details/79622015