TSQL--時間類型和毫秒數轉換


項目中使用BIGINT來存放時間,以下代碼用來轉換時間類型和BIGINT類型

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:   GGA
-- Create date: 2013-03-28
-- Description: 將時間類型轉化成BIGINT,返回指定時間
-- 到-01-01 08:00:00.000的毫秒數
-- =============================================
CREATE FUNCTION [dbo].[ufn_GetMSIntFormTime]
(
   @dt DATETIME
)
RETURNS BIGINT
AS
BEGIN
   -- Declare the return variable here
   DECLARE @dtInt BIGINT
 
   SELECT @dtInt=DATEDIFF(SECOND , '1970-01-01 08:00:00.000' , @dt ) --秒數
   set @dtInt = @dtInt*1000 + DATEPART(MILLISECOND,@dt) -- 毫秒數
   RETURN @dtInt
END
 
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:   GGA
-- Create date: 2013-03-28
-- Description: 根據毫秒數計算出時間
-- =============================================
CREATE FUNCTION [dbo].[ufn_GetTimeFormMSInt]
(
   @msINT BIGINT
)
RETURNS DATETIME
AS
  BEGIN
   DECLARE @secInt BIGINT
   DECLARE @leftMsInt BIGINT
  
   SET @secInt=@msINT/1000;
   SET @leftMsInt=@msINT%1000;
 
   DECLARE @date DATETIME
   SET @date = DATEADD(SECOND,@secInt,'1970-01-01 8:00:00:000')
   SET @date = DATEADD(MILLISECOND,@leftMsInt,@date)
   RETURN @date
 END
GO
 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM