新聞中心
如果需要返回一個(gè)時(shí)間段之間一個(gè)隨機(jī)時(shí)間,那么用SQL函數(shù)應(yīng)該如何表示呢?下面就將為您介紹返回一個(gè)時(shí)間段中某個(gè)隨機(jī)時(shí)間的Sql函數(shù)的例子,供您參考,希望對(duì)您學(xué)習(xí)SQL函數(shù)有所啟迪。

成都創(chuàng)新互聯(lián)-專(zhuān)業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性?xún)r(jià)比城區(qū)網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式城區(qū)網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋城區(qū)地區(qū)。費(fèi)用合理售后完善,十年實(shí)體公司更值得信賴(lài)。
SQL code
SET QUOTED_IDENTIFIER ON
GO
SET ANSI_NULLS ON
GO
/******************************
* 函數(shù)名: RandDateTime
* 作用: 返回兩個(gè)時(shí)間范圍內(nèi)的一個(gè)隨機(jī)時(shí)間
* 參數(shù):
* @RandNum: 0-1之際隨機(jī)數(shù)值 建議 Rand()
* @StartTime: 第一個(gè)時(shí)間
* @EndTime: 第二個(gè)時(shí)間
* Author: 蘭習(xí)剛
* Date: 2009-11-30
*******************************/
ALTER Function RandDateTime(@RandNum Decimal(38,18),@StartTime DateTime,@EndTime DateTime)
Returns DateTime
As
Begin
Declare @HourDiff Decimal(38,18) --兩個(gè)時(shí)間之間的小時(shí)差值
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) --取較小的時(shí)間
Set @HourDiff = Abs(@HourDiff)
ActionLable:
Declare @HourDecimal Decimal(38,18) --小時(shí)的小數(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í)的小數(shù)部分
Set @MsPartDiff = (@MsPartDiff + @HourDecimal * 3600*1000) * @RandNum
/*毫秒差值
由于之前@MsPartDiff是兩個(gè)時(shí)間小時(shí)之后的毫秒差值
@HourDecimal * 3600*1000 有小時(shí)的小數(shù)部分的毫秒差值 不會(huì)大于1小時(shí)
毫秒不會(huì)溢出
*/
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
【編輯推薦】
基于時(shí)間SQL函數(shù)詳解
巧用SQL函數(shù)實(shí)現(xiàn)身份證15位變18位
教您使用SQL中的TRUNC函數(shù)
詳解SQL中循環(huán)結(jié)構(gòu)的使用
SQL中表變量的不足
網(wǎng)頁(yè)標(biāo)題:返回一個(gè)時(shí)間段中某個(gè)隨機(jī)時(shí)間的Sql函數(shù)
瀏覽地址:http://www.5511xx.com/article/djppeei.html


咨詢(xún)
建站咨詢(xún)
