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

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条
...全文
77 点赞 收藏 2
写回复
2 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
helloha2013 2008-11-23
好像是 SELECT @OffSet = CHARINDEX(@FindString, [skinmain]) - 1
FROM [userskin]
WHERE CHARINDEX(@FindString, [skinmain]) <> 0
只提了最后一条记录,

但不知道怎么修改?
回复
virgo2008 2008-11-23
额!奇怪的事情还真多!
回复
相关推荐
发帖
ASP
创建于2007-09-28

2.8w+

社区成员

ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。
申请成为版主
帖子事件
创建了帖子
2008-11-23 01:22
社区公告
暂无公告