【叶子函数分享四十五】返回两个时间范围内的一个随机时间

/******************************

*    函数名:RandDateTime

*    作用: 返回两个时间范围内的一个随机时间

*    Author:    兰习刚

*    Date:      2009-11-30

*******************************/

go

--创建函数

create Function RandDateTime

(

    @RandNum Decimal(38,18),--0-1之际随机数值建议Rand()

    @StartTime DateTime,    --第一个时间

    @EndTime DateTime       --第二个时间

)

Returns DateTime

As

Begin

    Declare @HourDiff Decimal(38,18)    --两个时间之间的小时差值

    Declare @MsPartDiff Decimal(38,18)  --毫秒部分的差值  

    Declare @SmallDate DateTime

    Declare @ReturnDateTime DateTime   

   

    /*取各部分差值*/

    Set @HourDiff = DateDiff(hh,@StartTime,@EndTime)

    Set @MsPartDiff = Abs(DateDiff(ms,DateAdd(hh,@HourDiff,@StartTime),@EndTime))

    Select @SmallDate=(Case When @HourDiff>0 Then @StartTime Else @EndTime End)    --取较小的时间 

    Set @HourDiff = Abs(@HourDiff)

    ActionLable:

    Declare @HourDecimal Decimal(38,18)    --小时的小数部分  

    Declare @HourString varchar(200)

    Set @HourDiff = @HourDiff * @RandNum   

    Set @HourString = CONVERT(VARCHAR(200),@HourDiff)

    Set @HourString = SubString(@HourString,CharIndex('.',@HourString)+1,Len(@HourString))

    Set @HourString = '0.' + @HourString

    Set @HourDecimal = Convert(Decimal(38,18),@HourString)    --获得小时的小数部分

    Set @MsPartDiff = (@MsPartDiff + @HourDecimal * 3600*1000) * @RandNum   

    /*毫秒差值

    由于之前@MsPartDiff是两个时间小时之后的毫秒差值  

    @HourDecimal * 3600*1000 有小时的小数部分的毫秒差值不会大于小时

    毫秒不会溢出

    */

    Set @ReturnDateTime = DateAdd(hh,@HourDiff,@SmallDate)

    Set @ReturnDateTime = DateAdd(ms,@MsPartDiff,@ReturnDateTime)       

    Return @ReturnDateTime

End

 

--测试示例

select dbo.RandDateTime(Rand(),'2011-03-21 00:00:00.000','2011-03-21 23:59:00.000')

go 10

 

--运行结果

/*

-----------------------

2011-03-21 16:44:58.990

 

(1 row(s) affected)

 

 

-----------------------

2011-03-21 00:00:33.313

 

(1 row(s) affected)

 

 

-----------------------

2011-03-21 15:04:58.777

 

(1 row(s) affected)

 

 

-----------------------

2011-03-21 06:32:21.347

 

(1 row(s) affected)

 

 

-----------------------

2011-03-21 15:11:51.047

 

(1 row(s) affected)

 

 

-----------------------

2011-03-21 14:39:23.597

 

(1 row(s) affected)

 

 

-----------------------

2011-03-21 07:24:17.247

 

(1 row(s) affected)

 

 

-----------------------

2011-03-21 06:15:49.653

 

(1 row(s) affected)

 

 

-----------------------

2011-03-21 02:06:14.757

 

(1 row(s) affected)

 

 

-----------------------

2011-03-21 10:49:18.370

 

(1 row(s) affected)

*/

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值