奇哉怪也, 存储过程执行成功,数据却没有变化

helloha2013 2008-11-23 01:22:58
存储过程如下,意在更新数据库中超过8000个字符的ntext字段skinmain的值:

CREATE PROC dbo.SearchAndReplace
(
@FindString NVARCHAR(100)
,@ReplaceString NVARCHAR(100)
)
AS
BEGIN
SET NOCOUNT ON

DECLARE @TextPointer VARBINARY(16)
DECLARE @DeleteLength INT
DECLARE @OffSet INT

SELECT @TextPointer = TEXTPTR([skinmain])
FROM [userskin]

SET @DeleteLength = LEN(@FindString)
SET @OffSet = 0
SET @FindString = '%' + @FindString + '%'

WHILE (SELECT COUNT(*)
FROM [userskin]
WHERE CHARINDEX(@FindString, [skinmain]) <> 0) > 0
BEGIN
SELECT @OffSet = CHARINDEX(@FindString, [skinmain]) - 1
FROM [userskin]
WHERE CHARINDEX(@FindString, [skinmain]) <> 0

UPDATETEXT [userskin].[skinmain]
@TextPointer
@OffSet
@DeleteLength
@ReplaceString
END

SET NOCOUNT OFF
END
GO


查询分析器中执行 SearchAndReplace "http://127.0.0.1","/"
提示“命令已成功完成"

然后我再SELECT COUNT(*) AS Expr1
FROM userskin
WHERE (skinmain LIKE '%127.0.0.1%')

仍然返回原来的68条
...全文
116 2 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
helloha2013 2008-11-23
  • 打赏
  • 举报
回复
好像是 SELECT @OffSet = CHARINDEX(@FindString, [skinmain]) - 1
FROM [userskin]
WHERE CHARINDEX(@FindString, [skinmain]) <> 0
只提了最后一条记录,

但不知道怎么修改?
virgo2008 2008-11-23
  • 打赏
  • 举报
回复
额!奇怪的事情还真多!

28,409

社区成员

发帖
与我相关
我的任务
社区描述
ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。
社区管理员
  • ASP
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧