重慶分公司,新征程啟航
為企業提供網站建設、域名注冊、服務器等服務
為企業提供網站建設、域名注冊、服務器等服務
沒辦法,不可能一個庫一下全換了,沒那樣的操作。
創新互聯建站-專業網站定制、快速模板網站建設、高性價比延長網站開發、企業建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式延長網站制作公司更省心,省錢,快速模板網站建設找我們,業務覆蓋延長地區。費用合理售后完善,十年實體公司更值得信賴。
但你可以這樣操作。
1 檢查每張表的每個字段,查每個字符型的,字段,是否有可能有要修改的數據。這個的手工一個一個的確定下來。
2 update 表名 set 字段1?。健eplace (字段1,'原網址','新網址' ) .
這樣一個一個的替的話,也快,
REPLACE
用第三個表達式替換第一個字符串表達式中出現的所有第二個給定字符串表達式。
語法
REPLACE ( 'string_expression1' , 'string_expression2' , 'string_expression3' )
參數
'string_expression1'
待搜索的字符串表達式。string_expression1 可以是字符數據或二進制數據。
'string_expression2'
待查找的字符串表達式。string_expression2 可以是字符數據或二進制數據。
'string_expression3'
替換用的字符串表達式。string_expression3 可以是字符數據或二進制數據。
返回類型
如果 string_expression(1、2 或 3)是支持的字符數據類型之一,則返回字符數據。如果 string_expression(1、2 或 3)是支持的 binary 數據類型之一,則返回二進制數據。
示例
下例用 xxx 替換 abcdefghi 中的字符串 cde。
SELECT REPLACE('abcdefghicde','cde','xxx')
GO
下面是結果集:
------------
abxxxfghixxx
(1 row(s) affected)
方法一:varchar和nvarchar類型是支持replace,所以如果你的text不超過8000可以先轉換成前面兩種類型再使用replace 替換 text ntext 數據類型字段的語句 。
update 表名 set 字段名=replace(cast(與前面一樣的字段名 as varchar(8000)) ,'原本內容','想要替換成什么')方法二:
update [表名] set 字段名 = replace(與前面一樣的字段名,'原本內容','想要替換成什么')
你要看看你的A字段是什么類型。
如果是nvarchar
varchar等可以檢索的類型的話
用:
update
表
set
A=Replace(A,'aaa','bbb')
如果是ntext
text
類型的話,就麻煩點,看看一般文章內容的長度有多少?如果少于8000字符
update
表
set
A=Replace(convert(varchar(8000),A),'aaa','bbb')
如果字數比較多的話,就只能用程序從數據庫讀,然后用正則替換,再進行修改。
我目前就知道這些,看看有高人還有更好的方法沒
一、問題描述:
1。在Sql
Server
中,ntext/text/image
字段不允許應用replace函數替換內容;
2。通過convert字段轉換,可以把ntext字段轉換為varchar(8000),然后用Relpace函數替換,不過,此方法,對于字段長度大于8000的ntext字段無效。
二、問題解決
整理通用存儲過程,代碼如下:
復制代碼
代碼如下:
CREATE
procedure
[dbo].[Proc_UpdateNTextField]
@TargetTable
nvarchar(1000),
--目標表名
@TargetField
nvarchar(1000),
--目標字段名
@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
在告訴大家如何替換數據內容之前,我建議大家先了解一下SQL Server數據庫的數據存儲類型:在使用iwms系統的過程中,我們會經常遇到數據內容的替換操作。在告訴大家如何替換數據內容之前,我建議大家先了解一下SQLServer數據庫的數據存儲類型:SQLServer數據類型:以上是數據庫的基礎知識,是做網站的朋友都應該知道的內容(無論你使用什么cms),所以建議大家都耐心看一下。數據替換一般都發生在字符串數據字段中,除了ntext類型字段以外的其他字符串數據字段都可以使用以下的sql語句進行替換: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 [數據表名] SET [字段名] = REPLACE([字段名],'老字符串','新字符串') 比如,替換iwms文章數據表(iwms_news)中的標題字段(title)的部分內容,我們應該這么寫:UPDATE [iwms_news] SET [title] = REPLACE([title],'老字符串','新字符串') 上面的sql語句在iwms后臺的sql執行里面可以直接執行,基本上可以搞定所有的替換操作,但是由于ntext數據長度的原因,這一方法對ntext類型字段無效。那我們該用什么方法替換ntext類型字段的內容呢?方法有兩種:一是類型轉換,將ntext類型轉換為varchar類型,然后再用replace。適合于單頁內容最大長度4000的文章。update [數據表名] set [字段名] = replace(convert(varchar(4000), [字段名]),'老字符串','新字符串') 比如,替換iwms文章數據表(iwms_news)中的標題字段(content,ntext類型字段)的部分內容,我們應該這么寫:update iwms_news set [content] = replace(convert(varchar(4000),[content]),'老字符串','新字符串')二是SQLServer存儲過程declare @ptr varbinary(16) declare @artId int declare @Position int,@len int set @len = datalength('老字符串') declare wux_Cursor scroll Cursorforselect textptr([字段名]),[key字段名] from [數據表名] for read only open wux_Cursor fetch next from wux_Cursor into @ptr,@artId while @@fetch_status=0beginselect @Position=patindex('%老字符串%',[字段名]) from [數據表名] where [key字段名]=@artId while @Position0beginset @Position=@Position-1 updatetext [數據表名].[字段名] @ptr @Position @len '新字符串' select @Position=patindex('%老字符串%',[字段名]) from [數據表名] where [key字段名]=@artIdendfetch next from wux_Cursor into @ptr,@artIdendclose wux_cursor deallocate wux_cursor go比如,替換iwms文章數據表(iwms_news)中的標題字段(content,ntext類型字段)的部分內容,我們應該這么寫declare @ptr varbinary(16) declare @artId int declare @Position int,@len int set @len = datalength('老字符串')
如果保險一點的話最好加一個條件限制,就是where name like '%武漢生物',這樣替換的都是以“武漢生物”結尾的行