返回一個時間段中某個隨機時間的Sql函數(shù)
如果需要返回一個時間段之間一個隨機時間,那么用SQL函數(shù)應該如何表示呢?下面就將為您介紹返回一個時間段中某個隨機時間的Sql函數(shù)的例子,供您參考,希望對您學習SQL函數(shù)有所啟迪。
SQL code
SET QUOTED_IDENTIFIER ON
GO
SET ANSI_NULLS ON
GO
/******************************
* 函數(shù)名: RandDateTime
* 作用: 返回兩個時間范圍內的一個隨機時間
* 參數(shù):
* @RandNum: 0-1之際隨機數(shù)值 建議 Rand()
* @StartTime: 第一個時間
* @EndTime: 第二個時間
* Author: 蘭習剛
* Date: 2009-11-30
*******************************/
ALTER Function RandDateTime(@RandNum Decimal(38,18),@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) --小時的小數(shù)部分
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) --獲得小時的小數(shù)部分
Set @MsPartDiff = (@MsPartDiff + @HourDecimal * 3600*1000) * @RandNum
/*毫秒差值
由于之前@MsPartDiff是兩個時間小時之后的毫秒差值
@HourDecimal * 3600*1000 有小時的小數(shù)部分的毫秒差值 不會大于1小時
毫秒不會溢出
*/
Set @ReturnDateTime = DateAdd(hh,@HourDiff,@SmallDate)
Set @ReturnDateTime = DateAdd(ms,@MsPartDiff,@ReturnDateTime)
Return @ReturnDateTime
End
GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO
【編輯推薦】
巧用SQL函數(shù)實現(xiàn)身份證15位變18位