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
 
复制代码

 

posted on   笑东风  阅读(5077)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现

导航

点击右上角即可分享
微信分享提示