SQL 全角半角转换

if object_id(N'u_convert',N'FN') is not null

 drop   function u_convert

GO

create   function   u_convert(  

@str   nvarchar(4000),     

@flag   bit              

)

returns   nvarchar(4000)  

AS  

begin  

    declare   

          @pat nvarchar(8),

          @step   int,

          @i   int,

          @spc   int  

    if  @flag=0 

     begin 

       select   @pat=N'%[!-~]%',@step=-65248,  

       @str=replace(@str,N' ',N'   ')  

     end

    else  

     begin

       select   @pat=N'%[!-~]%',@step=65248,  

       @str=replace(@str,N'   ',N' ')  

     end

    set   @i=patindex(@pat   collate LATIN1_GENERAL_BIN,@str)  

    while   @i>0  

       select   @str=replace(@str,  

    substring(

               @str,@i,1), 

               nchar(unicode(substring(@str,@i,1))+@step)),

               @i=patindex(@pat   collate   LATIN1_GENERAL_BIN,@str)  

     return(@str)  

end  

GO

update t_rm_vip_info set card_id=dbo.u_convert(card_id,0)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值