26个日文片假名导致Access搜索(80040e14/内存溢出)的解决办法

来源:bbs.dvbbs.net  作者:V37
摘要:补充最新修改版,使用Unicode的字符代码,而不是非unicode(负数值,有时会出错)代码Jn0;Jn1;Jn2;Jn3;Jn4;Jn5;Jn6;Jn7;Jn8;Jn9;Jn10;Jn11;Jn12;Jn13;Jn14;Jn15;Jn16;Jn17;Jn1…

补充最新修改版,使用Unicode的字符代码,而不是非unicode(负数值,有时会出错)代码
Jn0; Jn1; Jn2; Jn3; Jn4; Jn5; Jn6; Jn7; Jn8; Jn9; Jn10; Jn11; Jn12; Jn13; Jn14; Jn15; Jn16; Jn17; Jn18; Jn19; Jn20; Jn21; Jn22; Jn23; Jn24; Jn25;
当字段内包含了这26个日文字符任意一个多个时,就会导致在执行SQL语句中包含了
[字段] like '%aaaaa%' 或 inStr(1,[字段],'aaaaa',1)>0
这样的查询时,毫无道理的出现了
"Microsoft JET Database Engine 错误 '80040e14' 内存溢出"的错误
其他Jet SQL函数命令未作测试,大概与字符搜索定位匹配相关的都可能出错

搜索相关资料得知被微软工程师证实是Access的bug,可能是语法关系都是微软的东东
在vbs中 执行inStr(1,日文平假名变量,"aaaaa",1)依然要出现错误
Microsoft VBScript 运行时错误 错误 '800a0005' 无效的过程调用或参数: 'instr'


没有搜索,因这几个字符出现Access的论坛网站搜索无法进行,何等痛苦
昨天一朋友大叫怪事,他的音乐数据库无法搜索了,只有30000条记录时是好的
毫无疑问,日文片假名是祸根,花几分钟把有包含上面的日文替换成"?"搜索顺利恢复
找来论坛程序用户群最大的动网dvBBS AC版本 7.0SP2 版测试,同样有这个日文发帖后 导致无法搜索并且运行时出错的问题
线上去搜索 '80040e14' 内存溢出" 的错误 多的是!

一简单有效的解决办法:
对这26个字符进行编码和解码,可能效率感觉不理想,测试下来问题不大,速度影响不是太大

编码:

Function Jencode(byVal iStr)
if isnull(iStr) or isEmpty(iStr) then
  Jencode=""
  Exit function
end if
dim F,i,E

E=array("Jn0;","Jn1;","Jn2;","Jn3;","Jn4;","Jn5;","Jn6;","Jn7;",_

"Jn8;","Jn9;","Jn10;","Jn11;","Jn12;","Jn13;","Jn14;","Jn15;",_

"Jn16;","Jn17;","Jn18;","Jn19;","Jn20;","Jn21;","Jn22;","Jn23;",_

"Jn24;","Jn25;")
  F=array(chrw(12468),chrw(12460),chrw(12462),chrw(12464),_

chrw(12466),chrw(12470),chrw(12472),chrw(12474),_

chrw(12485),chrw(12487),chrw(12489),chrw(12509),_

chrw(12505),chrw(12503),chrw(12499),chrw(12497),_

chrw(12532),chrw(12508),chrw(12506),chrw(12502),_

chrw(12500),chrw(12496),chrw(12482),chrw(12480),_

chrw(12478),chrw(12476))
  Jencode=iStr
  for i=0 to 25
   Jencode=replace(Jencode,F(i),E(i))
  next
End Function

【相关文章】好搜一下
MySQL中文索引解决方案:二元分词法

MySQL中文索引解决方案:二元分词法

首先,我们来想想MySQL不支持中文索引的关键原因还是中文是双字节的,如果能把中…