sqlserver 中ntext字段的批量替換(updatetext的用法)
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ò)程,代碼如下:
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 = 0 '
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 = 0 '
set @SqlStr = @SqlStr + ' begin '
set @SqlStr = @SqlStr + ' select @pos= patindex(''%' + @otxt + '%'',ProductDesc) from ProductTemp where ProductID=@id '
set @SqlStr = @SqlStr + ' while @pos>0 '
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
相關(guān)文章
SQL中Group分組獲取Top N方法實(shí)現(xiàn)可首選row_number
統(tǒng)計(jì)每個(gè)城市的最新10個(gè)產(chǎn)品本文采用了游標(biāo)方法/Count查詢/cross apply方法/row_number方法等等對(duì)比不難發(fā)現(xiàn)Group獲取Top N場(chǎng)景時(shí),可以首選row_number,游標(biāo)cursor其次,另外兩個(gè)就基本不考慮了2013-03-03sqlserver 實(shí)現(xiàn)收縮數(shù)據(jù)庫(kù)日志操作
這篇文章主要介紹了sqlserver 實(shí)現(xiàn)收縮數(shù)據(jù)庫(kù)日志操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01SqlServer 數(shù)據(jù)庫(kù) 三大 范式
本文將基于三大范式原則,結(jié)合具體的實(shí)例做簡(jiǎn)要分析,對(duì)SqlServer 數(shù)據(jù)庫(kù) 三大 范式相關(guān)知識(shí)感興趣的朋友一起看看吧2019-11-11跨服務(wù)器查詢導(dǎo)入數(shù)據(jù)的sql語(yǔ)句
此語(yǔ)句可用來(lái)將另一服務(wù)器中的數(shù)據(jù)插入到本數(shù)據(jù)庫(kù)中的某一表內(nèi)2009-10-10GridView自定義分頁(yè)的四種存儲(chǔ)過(guò)程
首先要說(shuō)說(shuō)為什么不用GridView的默認(rèn)的分頁(yè)功能,GridView控件并非真正知道如何獲得一個(gè)新頁(yè)面,它只是請(qǐng)求綁定的數(shù)據(jù)源控件返回適合規(guī)定頁(yè)面的行,分頁(yè)最終是由數(shù)據(jù)源控件完成。2009-12-12SQL Server高可用的常見(jiàn)問(wèn)題分析
SQL Server高可用不就是微軟的那幾個(gè)技術(shù)嗎,如Replication, Failover Clustering,本文將詳細(xì)介紹,有需求的朋友可以參考下2012-11-11sqlserver 支持定位當(dāng)前頁(yè),自定義排序的分頁(yè)SQL(拒絕動(dòng)態(tài)SQL)
sqlserver 支持定位當(dāng)前頁(yè),自定義排序的分頁(yè)SQL(拒絕動(dòng)態(tài)SQL)2010-05-05將備份的SQLServer數(shù)據(jù)庫(kù)轉(zhuǎn)換為SQLite數(shù)據(jù)庫(kù)操作方法
怎樣將備份的SQLServer數(shù)據(jù)庫(kù)轉(zhuǎn)換為SQLite數(shù)據(jù)庫(kù)操作方法:先要安裝好SQLServer2005,并且記住安裝時(shí)自己設(shè)置的用戶名和密碼,感興趣的朋友可以參考下啊,或許本文對(duì)你有所幫助2013-02-02SQL Server 開(kāi)窗函數(shù) Over()代替游標(biāo)的使用詳解
這篇文章主要介紹了SQL Server 開(kāi)窗函數(shù) Over()代替游標(biāo)的使用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10萬(wàn)能密碼的SQL注入漏洞其PHP環(huán)境搭建及防御手段
這篇文章主要介紹了萬(wàn)能密碼的SQL注入漏洞其PHP環(huán)境搭建及防御手段,對(duì)此感興趣的小伙伴趕快收藏起來(lái)吧2021-09-09