ACCESS模糊查询出现"内存溢出"

作者:hayden 来源:烦恼BLOG 时间:2009-08-13 14:25:00 

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

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

通过 模糊查询语句:

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")&%'

 痛苦,不太了解这网站的程序是谁写的,太不负责了。

标签:错误,access,内存溢出
0
投稿

猜你喜欢

  • 增加 javascript 的 trim 函数

    2008-04-20 16:54:00
  • javascript权威指南,学习笔记,之运算符号

    2008-04-20 16:43:00
  • ASP真正随机不重复查询代码

    2010-01-02 20:40:00
  • ASP和Javascript中取整函数的应用

    2009-06-07 18:38:00
  • ASP平台如何打造金牌英文网站

    2008-04-10 08:47:00
  • 2008圣诞节网站特色Logo不完全点评

    2008-12-25 18:35:00
  • 混乱的标记语言XHTML2/HTML5

    2009-07-31 14:27:00
  • SQL Server技巧之快速得到表的记录总数

    2011-01-04 14:36:00
  • asp如何实现强制登录注册?

    2010-05-24 18:13:00
  • 运行SQL Server的计算机间移动数据库

    2009-01-20 13:07:00
  • ASP实例:即时显示当前页面浏览人数

    2008-04-19 22:02:00
  • 网页栅格系统研究(4):技术实现

    2008-11-06 11:44:00
  • SQL 2008邮件故障排除:发送测试电子邮件

    2008-12-02 14:28:00
  • 如何增强网站数据库Access文件的安全性

    2008-11-13 16:58:00
  • Dreamweaver量身打造Wordpress留言板

    2009-12-09 17:08:00
  • 2个asp防刷新程序代码

    2008-09-28 21:16:00
  • Html的几个小技巧

    2011-04-29 14:02:00
  • Javascript语法检查插件 jsLint for Vim

    2009-03-11 16:37:00
  • SQL server使用自定义函数以及游标

    2011-11-03 17:26:27
  • SQL SERVER查询所有数据库名,表名,和字段名的语句

    2012-01-05 19:25:26
  • asp之家 网络编程 m.aspxhome.com