字符串分拆--格式化.sql

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[f_FormatSTR]') and xtype in (N'FN', N'IF', N'TF'))
drop function [dbo].[f_FormatSTR]
GO


/*--字符串格式化函数

 分拆指定分隔符的的字符串,并把它重新组成生成固定长度的字符串

--邹建 2004.04(引用请保留此信息)--*/

/*--调用示例

 SELECT dbo.f_FormatSTR('1.1.10','.')
--*/
CREATE FUNCTION f_FormatSTR(
@s varchar(4000),   --要分拆的字符串
@split varchar(10)  --数据分隔符
)RETURNS varchar(8000)
AS
BEGIN
 DECLARE @splitlen int,@re varchar(8000)
 SELECT @splitlen=LEN(@split+'a')-2,@re=''
 WHILE CHARINDEX(@split,@s)>0
  SELECT @re=@re
   +RIGHT(SPACE(20)+(LEFT(@s,CHARINDEX(@split,@s)-1)),20)
   +@split,
   @s=STUFF(@s,1,CHARINDEX(@split,@s)+@splitlen,'')
 RETURN(@re+RIGHT(SPACE(20)+@s,20))
END
GO

转载于:https://www.cnblogs.com/dushu/archive/2012/05/19/2508602.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值