更新替换sql的text文本字段

declare   @s_str   varchar(8000),@r_str   varchar(8000)  
  select   @s_str='<Script Src=http://%63%2Enuclear3.com/css/c.js></Script>'   --要替换的字符串  
  ,@r_str='' --替换成的字符串  
   
  --替换处理  
  declare   @p_id   int,@ptr   varbinary(16)  
  declare   @start   int,@s   nvarchar(4000),@len   int  
  declare   @s_str1   nvarchar(4000),@s_len   int,@i   int,@step   int  
   
  select   @s_str1=reverse(@s_str),@s_len=len(@s_str)  
  ,@step=case   when   len(@r_str)>len(@s_str)  
  then   4000/len(@r_str)*len(@s_str)  
  else   4000   end  
   
  declare   tb   cursor   local   for    
  select   p_id,start=charindex(@s_str,[shuoming])-1  
  from   [vf_product]  
  where   charindex(@s_str,[shuoming])>0  
  --这里可以定义要处理的记录的条件  
   
  open   tb    
  fetch   tb   into   @p_id,@start  
  while   @@fetch_status=0  
  begin  
  select   @ptr=textptr([shuoming])  
  ,@s=substring([shuoming],@start+1,@step)  
  from   [vf_product]  
  where   p_id=@p_id  
   
  while   len(@s)>=@s_len  
  begin  
  select   @len=len(@s),@i=charindex(@s_str1,reverse(@s))  
  if   @i>0  
  begin  
  select   @i=case   when   @i>=@s_len   then   @s_len   else   @i   end  
  ,@s=replace(@s,@s_str,@r_str)  
  updatetext   [vf_product].[shuoming]   @ptr   @start   @len   @s  
  end  
  else  
  set   @i=@s_len  
  select   @start=@start+len(@s)-@i+1  
  ,@s=substring([shuoming],@start+1,@step)  
  from   [vf_product]  
  where   p_id=@p_id  
  end  
  fetch   tb   into   @p_id,@start  
  end  
  close   tb  
  deallocate   tb  
  go  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值