首页后端开发ASP.NETASP在ACCESS中模糊查询"内存溢出"的解决方法

ASP在ACCESS中模糊查询"内存溢出"的解决方法

时间2024-02-07 15:33:03发布访客分类ASP.NET浏览386
导读:收集整理的这篇文章主要介绍了ASP在ACCESS中模糊查询"内存溢出"的解决方法,觉得挺不错的,现在分享给大家,也给大家做个参考。 今天在日常维护一个网站时,发现该网站的留言程序没有经过...
收集整理的这篇文章主要介绍了ASP在ACCESS中模糊查询"内存溢出"的解决方法,觉得挺不错的,现在分享给大家,也给大家做个参考。

今天在日常维护一个网站时,发现该网站的留言程序没有经过严格的验证过滤,导致了将近十万条垃圾数据。而其中又不乏重要信息,需要清理数据,以及增加更为严格的验证措施。

而通过在数据库中直接删除又不太科学,会误删很多重要信息。

通过 模糊查询语句:
@H_512_7@复制代码 代码如下:
select * From Feedback where Comments like '%http%'

结果:“内存溢出”

经过不断的搜索,找出了问题的主要原因:

asp 中用 LIKE 关键字查询日文符号就会出错,比如说Chr(-23075),提示内存溢出。
如果数据表中的数据包含日文或者一些特殊非简体汉字符号,也会出现内存溢出的错误。


而网上说,上述问题已经得到微软动力营的微软工程师确认,为产品的 BUG,无法解决。唯一的办法就是将整个数据库中的数据编码为ANSI 文本格式,然后保存。显示的时候再DECODE。

无解,只有按上面所说,进行字段转换保存到另外一个新字段中,然后再进行清理操作。面对这个超标数据真是困难。

EncodeString 函数进行字符转义

复制代码 代码如下:
Function EncodeString(strWords)
    Dim i As Long
    Dim strEncodeWords
    For i = 1 To Len(strWords)
        strEncodeWords = strEncodeWords & CStr(Asc(Mid(strWords, i, 1))) & ","
    Next

    EncodeString = strEncodeWords
End Function

这样经过转义后,在模糊搜索时,将关键字进行转义一下

复制代码 代码如下:
delete * from Feedback where Comments_new like '%& EncodeString("http")& %'

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: ASP在ACCESS中模糊查询"内存溢出"的解决方法
本文地址: https://pptw.com/jishu/604225.html
asp页面提高的访问速度的方法详解 ASP转换格林威治时间函数DateDiff()应用

游客 回复需填写必要信息