一、問(wèn)題描述:

創(chuàng)新互聯(lián)-云計(jì)算及IDC服務(wù)提供商,涵蓋公有云、IDC機(jī)房租用、西云機(jī)房、等保安全、私有云建設(shè)等企業(yè)級(jí)互聯(lián)網(wǎng)基礎(chǔ)服務(wù),聯(lián)系電話:18982081108
1。在Sql
Server
中,ntext/text/image
字段不允許應(yīng)用replace函數(shù)替換內(nèi)容;
2。通過(guò)convert字段轉(zhuǎn)換,可以把ntext字段轉(zhuǎn)換為varchar(8000),然后用Relpace函數(shù)替換,不過(guò),此方法,對(duì)于字段長(zhǎng)度大于8000的ntext字段無(wú)效。
二、問(wèn)題解決
整理通用存儲(chǔ)過(guò)程,代碼如下:
復(fù)制代碼
代碼如下:
CREATE
procedure
[dbo].[Proc_UpdateNTextField]
@TargetTable
nvarchar(1000),
--目標(biāo)表名
@TargetField
nvarchar(1000),
--目標(biāo)字段名
@PKField
nvarchar(1000),
--該表主鍵字段名
@otxt
nvarchar(1000),
--需要替換的字符串
@ntxt
nvarchar(1000)
--替換后的字符串
as
begin
declare
@SqlStr
nvarchar(4000)
set
@SqlStr
=
'
declare
@txtlen
int
'
set
@SqlStr
=
@SqlStr
+
'
set
@txtlen
=
len('''
+
@otxt
+
''')
'
set
@SqlStr
=
@SqlStr
+
'
declare
@pos
int
'
set
@SqlStr
=
@SqlStr
+
'
set
@pos
=
'
set
@SqlStr
=
@SqlStr
+
'declare
curs
cursor
local
fast_forward
for
select
'
set
@SqlStr
=
@SqlStr
+
@PKField
+
'
,
textptr('
+
@TargetField
+')
from
'
+
@TargetTable
+'
where
'
+
@TargetField
+
'
like
''%'
+
@otxt
+'%'''
set
@SqlStr
=
@SqlStr
+
'
declare
@ptr
binary(16)
'
set
@SqlStr
=
@SqlStr
+
'
declare
@id
char(32)
'
set
@SqlStr
=
@SqlStr
+
'
open
curs
'
set
@SqlStr
=
@SqlStr
+
'
fetch
next
from
curs
into
@id,
@ptr
'
set
@SqlStr
=
@SqlStr
+
'
while
@@fetch_status
=
'
set
@SqlStr
=
@SqlStr
+
'
begin
'
set
@SqlStr
=
@SqlStr
+
'
select
@pos=
patindex(''%'
+
@otxt
+
'%'',ProductDesc)
from
ProductTemp
where
ProductID=@id
'
set
@SqlStr
=
@SqlStr
+
'
while
@pos0
'
set
@SqlStr
=
@SqlStr
+
'
begin
'
set
@SqlStr
=
@SqlStr
+
'
set
@pos=@pos-1
'
set
@SqlStr
=
@SqlStr
+
'
updatetext
'
+
@TargetTable
+
'.'
+@TargetField
+
'
@ptr
@pos
@txtlen
'''
+
@ntxt
+
'''
'
set
@SqlStr
=
@SqlStr
+
'
select
@pos=
patindex(''%'
+
@otxt
+
'%'',ProductDesc)
from
ProductTemp
where
ProductID=@id
'
set
@SqlStr
=
@SqlStr
+
'
end
'
set
@SqlStr
=
@SqlStr
+
'
fetch
next
from
curs
into
@id,
@ptr
'
set
@SqlStr
=
@SqlStr
+
'
end
'
set
@SqlStr
=
@SqlStr
+
'
close
curs
'
set
@SqlStr
=
@SqlStr
+
'
deallocate
curs
'
EXECUTE
sp_executesql
@SqlStr
end
你要看看你的A字段是什么類型。
如果是nvarchar
varchar等可以檢索的類型的話
用:
update
表
set
A=Replace(A,'aaa','bbb')
如果是ntext
text
類型的話,就麻煩點(diǎn),看看一般文章內(nèi)容的長(zhǎng)度有多少?如果少于8000字符
update
表
set
A=Replace(convert(varchar(8000),A),'aaa','bbb')
如果字?jǐn)?shù)比較多的話,就只能用程序從數(shù)據(jù)庫(kù)讀,然后用正則替換,再進(jìn)行修改。
我目前就知道這些,看看有高人還有更好的方法沒(méi)
在告訴大家如何替換數(shù)據(jù)內(nèi)容之前,我建議大家先了解一下SQL Server數(shù)據(jù)庫(kù)的數(shù)據(jù)存儲(chǔ)類型:在使用iwms系統(tǒng)的過(guò)程中,我們會(huì)經(jīng)常遇到數(shù)據(jù)內(nèi)容的替換操作。在告訴大家如何替換數(shù)據(jù)內(nèi)容之前,我建議大家先了解一下SQLServer數(shù)據(jù)庫(kù)的數(shù)據(jù)存儲(chǔ)類型:SQLServer數(shù)據(jù)類型:以上是數(shù)據(jù)庫(kù)的基礎(chǔ)知識(shí),是做網(wǎng)站的朋友都應(yīng)該知道的內(nèi)容(無(wú)論你使用什么cms),所以建議大家都耐心看一下。數(shù)據(jù)替換一般都發(fā)生在字符串?dāng)?shù)據(jù)字段中,除了ntext類型字段以外的其他字符串?dāng)?shù)據(jù)字段都可以使用以下的sql語(yǔ)句進(jìn)行替換:update [swf_Upload] set [Dir] = replace([Dir],'200901/14','200901/15')update [swf_Content] set [Description] =replace([Description],'200901/14','200901/15')update [swf_Content_01] set [content] = replace(convert(varchar(4000), [content]),'200901/14','200901/15') UPDATE [數(shù)據(jù)表名] SET [字段名] = REPLACE([字段名],'老字符串','新字符串') 比如,替換iwms文章數(shù)據(jù)表(iwms_news)中的標(biāo)題字段(title)的部分內(nèi)容,我們應(yīng)該這么寫(xiě):UPDATE [iwms_news] SET [title] = REPLACE([title],'老字符串','新字符串') 上面的sql語(yǔ)句在iwms后臺(tái)的sql執(zhí)行里面可以直接執(zhí)行,基本上可以搞定所有的替換操作,但是由于ntext數(shù)據(jù)長(zhǎng)度的原因,這一方法對(duì)ntext類型字段無(wú)效。那我們?cè)撚檬裁捶椒ㄌ鎿Qntext類型字段的內(nèi)容呢?方法有兩種:一是類型轉(zhuǎn)換,將ntext類型轉(zhuǎn)換為varchar類型,然后再用replace。適合于單頁(yè)內(nèi)容最大長(zhǎng)度4000的文章。update [數(shù)據(jù)表名] set [字段名] = replace(convert(varchar(4000), [字段名]),'老字符串','新字符串') 比如,替換iwms文章數(shù)據(jù)表(iwms_news)中的標(biāo)題字段(content,ntext類型字段)的部分內(nèi)容,我們應(yīng)該這么寫(xiě):update iwms_news set [content] = replace(convert(varchar(4000),[content]),'老字符串','新字符串')二是SQLServer存儲(chǔ)過(guò)程declare @ptr varbinary(16) declare @artId int declare @Position int,@len int set @len = datalength('老字符串') declare wux_Cursor scroll Cursorforselect textptr([字段名]),[key字段名] from [數(shù)據(jù)表名] for read only open wux_Cursor fetch next from wux_Cursor into @ptr,@artId while @@fetch_status=0beginselect @Position=patindex('%老字符串%',[字段名]) from [數(shù)據(jù)表名] where [key字段名]=@artId while @Position0beginset @Position=@Position-1 updatetext [數(shù)據(jù)表名].[字段名] @ptr @Position @len '新字符串' select @Position=patindex('%老字符串%',[字段名]) from [數(shù)據(jù)表名] where [key字段名]=@artIdendfetch next from wux_Cursor into @ptr,@artIdendclose wux_cursor deallocate wux_cursor go比如,替換iwms文章數(shù)據(jù)表(iwms_news)中的標(biāo)題字段(content,ntext類型字段)的部分內(nèi)容,我們應(yīng)該這么寫(xiě)declare @ptr varbinary(16) declare @artId int declare @Position int,@len int set @len = datalength('老字符串')
文章名稱:sqlserver替換,sqlserver替換字段某字符
文章網(wǎng)址:http://chinadenli.net/article33/dsicdps.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、網(wǎng)站制作、做網(wǎng)站、動(dòng)態(tài)網(wǎng)站、面包屑導(dǎo)航、企業(yè)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)