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之类的不能放在函数的本身执行,只能通过传入参数带入

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值