日期:2014-05-20  浏览次数:21046 次

请教关于Jdbc中setString()问题
setString()对于符号是不是有什么特殊的限制呀?

我在java中使用jdbc的接口setString()方法向oracle的存储过程传参数的时候,遇到了一个很奇怪的问题!如果传入的参数中的字符数量(%)超过60个(在60个以内没有问题!),对于在oracle中的sql进行模糊检索(使用like语句),却不能得到任何纪录,但是如果直接在pl/sql   developer   中使用没有问题!这是怎么回事呀?大家有没有遇到过呢?

比如:
在java中
……
stmt.setString(1,   "%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% ");
……
如果上面的%超过60个,那么通过stmt.execute()执行后的结果,没有任何值返回!
在60个以内没有问题!

在pl/sql中
select   *  
from   table1  
where   colum   like   ' "%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% '
在这里没有这个限制,但必须要在2000个字节以内!

------解决方案--------------------
up
------解决方案--------------------
楼主搞测试的?要输入这么怪的数据.
不太清楚
------解决方案--------------------
Lz在进行压力测试么?这样做似乎没什么实际意义。
既然Pl/sql 运行没有问题,那就说明是stmt.setString()函数的问题。