Sqlserver 自定义实用函数集(不定期更新)

1. 删除字符串中符合正规表达的字符

CREATE FUNCTION fun_regex_del 
(
    @inStr VARCHAR(MAX),
    @expression VARCHAR(MAX)
)
RETURNS VARCHAR(MAX)
AS
BEGIN
    DECLARE @str_userlist VARCHAR(MAX);
    SET @str_userlist = @inStr;

    DECLARE @i INT;
    SET @i = 0;

    WHILE PATINDEX(@expression,@str_userlist) > 0  
    BEGIN  
        SET @i = PATINDEX(@expression,@str_userlist)  
        SET @str_userlist = STUFF(@str_userlist,@i,1,'')  
    END   

    RETURN @str_userlist;
END

GO

2. URLDecode

CREATE FUNCTION [dbo].[SP_fnURLDecode] ( @input NVARCHAR(4000) )
RETURNS NVARCHAR(4000)
AS 
    BEGIN 

        DECLARE @char NVARCHAR(4)
        DECLARE @asc NVARCHAR(4)
        DECLARE @asc2 NVARCHAR(4)

        WHILE ( CHARINDEX('%', @input) > 0 ) 
            BEGIN
                SET @char = ( SELECT    SUBSTRING(@input,
                                                  CHARINDEX('%', @input) + 1,
                                                  2)
                            )
                IF ( ISNUMERIC(SUBSTRING(@char, 1, 1)) ) > 0 
                    BEGIN
                        SET @asc = ( SELECT CAST(SUBSTRING(@char, 1, 1) AS INT)
                                   ) * 16
                    END
                ELSE 
                    BEGIN 
                        SET @asc = ( SELECT ASCII(CAST(SUBSTRING(@char, 1, 1) AS CHAR))
                                   ) - 55
                        SET @asc = ( SELECT @asc * 16
                                   )
                    END
                IF ( ISNUMERIC(SUBSTRING(@char, 2, 1)) ) > 0 
                    SET @asc = ( SELECT CAST(@asc AS INT)
                                        + ( SELECT  CAST(SUBSTRING(@char, 2, 1) AS INT)
                                          )
                               )
                ELSE 
                    BEGIN 
                        SET @asc2 = ( SELECT    ASCII(CAST(SUBSTRING(@char, 2,
                                                              1) AS CHAR))
                                    ) - 55
                        SET @asc = ( SELECT CAST(@asc AS INT)
                                            + ( SELECT  CAST(@asc2 AS INT)
                                              )
                                   )
                    END
                SET @input = ( SELECT   SUBSTRING(@input, 0,
                                                  CHARINDEX('%', @input))
                             ) + CHAR(@asc)
                    + ( SELECT  SUBSTRING(@input, CHARINDEX('%', @input) + 3,
                                          LEN(@input))
                      )
            END
        RETURN @input
    END


GO
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

24K老游

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值