代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
MSSQL
】
sqlserver 中ntext字段的批量替换
作者:
彩连
/ 发布于
2017/9/14
/
880
一、问题描述: 1。在Sql Server 中,ntext/text/image 字段不允许应用replace函数替换内容; 2。通过convert字段转换,可以把ntext字段转换为varchar(8000),然后用Relpace函数替换,不过,此方法,对于字段长度大于8000的ntext字段无效。
USE [sitefactory] GO /****** Object: StoredProcedure [dbo].[Proc_UpdateNTextField] Script Date: 03/31/2015 13:26:31 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO 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 = 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 + '%'','+@TargetField+') from '+@TargetTable+' where '+@PKField+'=@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 + '%'','+@TargetField+') from '+@TargetTable+' where '+@PKField+'=@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 GO 使用例子: use sitefactory exec dbo.Proc_UpdateNTextField 'pe_u_article','content','id','{PE.SiteConfig.uploaddir/}','upload'
试试其它关键字
同语言下
.
SQL查询 多列合并成一行用逗号隔开
.
查看存储过程修改时间,最近执行时间
.
设置手动批量删除数据库相关进程
.
获取某个表中特定字段的所有字符串形式
.
SQL 如何去除重复的字符串
.
怎么去掉一个字段中的重复数据
.
String 去除空格 回车 换行 水平制表符
.
SQL查询和替换含有回车,空格,TAB
.
SQL SERVER 查询每日新增用户数量、次留数量
.
判断两个字符串是否存在相同的内容
可能有用的
.
SQL查询 多列合并成一行用逗号隔开
.
查看存储过程修改时间,最近执行时间
.
设置手动批量删除数据库相关进程
.
获取某个表中特定字段的所有字符串形式
.
SQL 如何去除重复的字符串
.
怎么去掉一个字段中的重复数据
.
String 去除空格 回车 换行 水平制表符
.
SQL查询和替换含有回车,空格,TAB
.
SQL SERVER 查询每日新增用户数量、次留数量
.
判断两个字符串是否存在相同的内容
彩连
贡献的其它代码
(
14
)
.
Springmvc 上传文件MultipartFile 转File
.
sqlserver 中ntext字段的批量替换
.
百度API从经纬度坐标到地址的转换服务
.
CollectionHelper-网页采集辅助类
.
标准输出
.
实现appStore内购的服务器端验证
.
获取系统版本信息方法
.
根据ip获取城市等相关信息
.
通过ip获取地理信息
.
获取运行平台系统信息
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3