ASP在ACCESS中模糊查询"内存溢出"的解决方法
程序员文章站
2022-07-02 18:20:44
今天在日常维护一个网站时,发现该网站的留言程序没有经过严格的验证过滤,导致了将近十万条垃圾数据。而其中又不乏重要信息,需要清理数据,以及增加更为严格的验证措施。
而通过在...
今天在日常维护一个网站时,发现该网站的留言程序没有经过严格的验证过滤,导致了将近十万条垃圾数据。而其中又不乏重要信息,需要清理数据,以及增加更为严格的验证措施。
而通过在数据库中直接删除又不太科学,会误删很多重要信息。
通过 模糊查询语句:
复制代码 代码如下:
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")&%'
上一篇: 昌平君芈启,他这一生有何功成名就?
下一篇: MongoDB通配符索引的用法实例