首页 > 数据库技术 > 详细

SqlServer时间格式不足2位补0

时间:2020-05-26 20:35:12      阅读:264      评论:0      收藏:0      [点我收藏+]

 

CREATE FUNCTION [dbo].[FULL_TIME](@Times NVARCHAR(50))
 RETURNS NVARCHAR(50)
 AS
 BEGIN
 DECLARE @return NVARCHAR(50)
 SET @return =(
  select case len(SUBSTRING(@Times,0,CHARINDEX(‘:‘, @Times, 0)))
 when 1
 then ‘0‘+SUBSTRING(@Times,0,CHARINDEX(‘:‘,@Times, 0))
  else SUBSTRING(@Times,0,CHARINDEX(‘:‘,@Times, 0)) end
  +‘:‘+case LEN(SUBSTRING(@Times,CHARINDEX(‘:‘, @Times, 0)+1,
 (CHARINDEX(‘:‘, @Times, CHARINDEX(‘:‘,@Times, 0)+1)-CHARINDEX(‘:‘,@Times, 0))-1) )
  when 1
  then ‘0‘+SUBSTRING(@Times,CHARINDEX(‘:‘, @Times, 0)+1,
 (CHARINDEX(‘:‘, @Times, CHARINDEX(‘:‘,@Times, 0)+1)-CHARINDEX(‘:‘,@Times, 0))-1)
  else SUBSTRING(@Times,CHARINDEX(‘:‘, @Times, 0)+1,
 (CHARINDEX(‘:‘,@Times, CHARINDEX(‘:‘,@Times, 0)+1)-CHARINDEX(‘:‘,@Times, 0))-1)  end
 +‘:‘+
 case LEN(SUBSTRING(@Times,CHARINDEX(‘:‘,@Times, CHARINDEX(‘:‘,@Times, 0)+1)+1,5))
 when 1
 then ‘0‘+SUBSTRING(@Times,CHARINDEX(‘:‘,@Times, CHARINDEX(‘:‘,@Times, 0)+1)+1,5)
 else SUBSTRING(@Times,CHARINDEX(‘:‘, @Times, CHARINDEX(‘:‘, @Times, 0)+1)+1,5) end )
 RETURN @return
 END

 select dbo.FULL_TIME(‘3:1:2‘)  --结果:  03:01:02

SqlServer时间格式不足2位补0

原文:https://www.cnblogs.com/pzxnet/p/12967286.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!