数据库字符串内容批量替换更新
|
admin
2011年3月3日 20:41
本文热度 3075
|
数据库经常会遇到需要把一些内容白批量替换的问题,有时是因为存数据时没有编码,有时是因为有些不良的信息,要直接替换。
整理了下如何用
SQL语句来替换:
替换指定列内容语句
update [t_test] set [detail] = REPLACE([detail],'打到XXX','新字符串')
注意,这个语句是不能替换
ntext的,除了
ntext类型的字符类型是可以全部替换
如果要替换
ntext类型字段是需要进行类型转换
update [t_test] set [detail] = replace(convert(varchar(4000), [detail]),'打到XXX','新字符串') where id<4
写一小段SQL来执行完成整个数据表的替换
- SQL code复制代码
declare @ptr varbinary(16)
declare @artId int
declare @Position int,@len int
set @len = datalength('XXXA')
declare wux_Cursor scroll Cursor
for
select textptr([detail]),id from t_test
for read only
open wux_Cursor
fetch next from wux_Cursor into @ptr,@artId
while @@fetch_status=0
begin
select @Position=patindex('%打到XXX%',[detail]) from t_test where id=@artId
while @Position>0
begin
set @Position=@Position-1
updatetext [t_test].[detail] @ptr @Position @len 'XXXA'
select @Position=patindex('%打到XXX%',detail) from t_test where id=@artId
end
fetch next from wux_Cursor into @ptr,@artId
end
close wux_cursor
deallocate wux_cursor
go
该文章在 2011/3/3 20:41:40 编辑过