SQL text字段的替换处理(无法批量更新,写法记录)

注: SQL2005以上版本直接使用varchar(max)的replace即可

此处只是记录一种写法

 

/* --text字段的替换处理 
--
*/ 
-- 创建数据测试环境 
create    table   #tb(aa    text
insert    into   #tb   
select    ' abc123abc123,asd  ' 

-- 定义替换的字符串 
declare    @s_str    varchar( 8000), @d_str    varchar( 8000
select    @s_str =  ' 123  '    -- 要替换的字符串 
, @d_str =  ' 000  '  -- 替换成的字符串 

-- 字符串替换处理 
declare    @p    varbinary( 16), @postion    int, @rplen    int 
select    @p = textptr(aa), @rplen = len( @s_str), @postion = charindex( @s_str,aa) - 1    from   #tb 
while    @postion >  0 
begin 
updatetext   #tb.aa    @p    @postion    @rplen    @d_str 
select    @postion = charindex( @s_str,aa) - 1    from   #tb 
end 

-- 显示结果 
select    *    from   #tb 

-- 删除数据测试环境 
drop    table   #tb 

转载于:https://www.cnblogs.com/hejunrex/archive/2012/04/24/2468823.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值