ASP在ACCESS中模糊查詢"內(nèi)存溢出"的解決方法
今天在日常維護(hù)一個(gè)網(wǎng)站時(shí),發(fā)現(xiàn)該網(wǎng)站的留言程序沒(méi)有經(jīng)過(guò)嚴(yán)格的驗(yàn)證過(guò)濾,導(dǎo)致了將近十萬(wàn)條垃圾數(shù)據(jù)。而其中又不乏重要信息,需要清理數(shù)據(jù),以及增加更為嚴(yán)格的驗(yàn)證措施。
而通過(guò)在數(shù)據(jù)庫(kù)中直接刪除又不太科學(xué),會(huì)誤刪很多重要信息。
通過(guò) 模糊查詢語(yǔ)句:
select * from Feedback where Comments like '%http%'
結(jié)果:“內(nèi)存溢出”
經(jīng)過(guò)不斷的搜索,找出了問(wèn)題的主要原因:
asp 中用 LIKE 關(guān)鍵字查詢?nèi)瘴姆?hào)就會(huì)出錯(cuò),比如說(shuō)Chr(-23075),提示內(nèi)存溢出。
如果數(shù)據(jù)表中的數(shù)據(jù)包含日文或者一些特殊非簡(jiǎn)體漢字符號(hào),也會(huì)出現(xiàn)內(nèi)存溢出的錯(cuò)誤。
而網(wǎng)上說(shuō),上述問(wèn)題已經(jīng)得到微軟動(dòng)力營(yíng)的微軟工程師確認(rèn),為產(chǎn)品的 BUG,無(wú)法解決。唯一的辦法就是將整個(gè)數(shù)據(jù)庫(kù)中的數(shù)據(jù)編碼為ANSI 文本格式,然后保存。顯示的時(shí)候再DECODE。
無(wú)解,只有按上面所說(shuō),進(jìn)行字段轉(zhuǎn)換保存到另外一個(gè)新字段中,然后再進(jìn)行清理操作。面對(duì)這個(gè)超標(biāo)數(shù)據(jù)真是困難。
EncodeString 函數(shù)進(jìn)行字符轉(zhuǎn)義
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
這樣經(jīng)過(guò)轉(zhuǎn)義后,在模糊搜索時(shí),將關(guān)鍵字進(jìn)行轉(zhuǎn)義一下
delete * from Feedback where Comments_new like '%&EncodeString("http")&%'
相關(guān)文章
再發(fā)幾個(gè)ASP不錯(cuò)的函數(shù)
再發(fā)幾個(gè)ASP不錯(cuò)的函數(shù)...2007-08-08utf-8 網(wǎng)頁(yè)不顯示+utf-8網(wǎng)頁(yè)亂碼的通用解決方法
當(dāng)我們?cè)跒g覽或使用uft-8格式的頁(yè)面的時(shí)候,總有可能出現(xiàn)一些亂碼或不顯示的問(wèn)題,下載就瀏覽器客戶端和服務(wù)器都有一些原因的分析與解決方法2008-10-10windows2003下使用asp WScript.Shell的設(shè)置方法
在windows2000下,IIS默認(rèn)設(shè)置是可以web和可執(zhí)行程序通信的。但是在2003下IIS關(guān)于這方面的服務(wù)是禁止的。2007-12-12ASP中格式化時(shí)間短日期補(bǔ)0變兩位長(zhǎng)日期的方法
這篇文章主要介紹了ASP中格式化時(shí)間短日期補(bǔ)0變兩位長(zhǎng)日期的方法,需要的朋友可以參考下2020-04-04asp代碼實(shí)現(xiàn)檢測(cè)組件是否安裝的函數(shù)
asp代碼實(shí)現(xiàn)檢測(cè)組件是否安裝的函數(shù)...2007-08-08JavaScript在ASP頁(yè)面中實(shí)現(xiàn)掩碼文本框效果代碼
在網(wǎng)頁(yè)中輸日期、時(shí)間、IP地址等需要一定的格式限制,否則將會(huì)程序?qū)?huì)很難和程序溝通2012-08-08