原问题,基本的要求是:
3-10 格式化成 00030010
3-10-1 格式化成 00030010001
....
10 格式化成 0010
10-1 格式化成 0010001
参考答案:
CREATE FUNCTION fn_Format(@S nvarchar(100),@Key nvarchar(10),@Len int)
RETURNS nvarchar(100)
AS
BEGIN
DECLARE @Temp nvarchar(50)
IF CHARINDEX(@Key,@S)>0
BEGIN
SET @Temp=left(@S,CHARINDEX(@Key,@S)-1)
SET @Temp= RIGHT(POWER(10,@Len-LEN(@Temp)),@Len-LEN(@Temp))+@Temp
SET @S=@Temp+dbo.fn_Format(RIGHT(@S,LEN(@S)-CHARINDEX(@Key,@S)),@Key,@Len)
END
ELSE
SET @S= RIGHT(POWER(10,@Len-LEN(@S)),@Len-LEN(@S))+@S
RETURN @S
END
GO
PRINT dbo.fn_Format('2','-',4)
PRINT dbo.fn_Format('3-10','-',4)
PRINT dbo.fn_Format('3-10-1','-',4)
DROP FUNCTION fn_Format
/*
结果:
0002
00030010
000300100001
*/
问题来源:http://community.csdn.net/Expert/topic/5345/5345618.xml?temp=.2492182
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/7764484/viewspace-898732/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/7764484/viewspace-898732/