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

PreparedStatement executeBatch()的返回值的问题
用的是 ORACLE

addBatch的时候,我加了,5条数据。
可返回给我的int[] 数组 中的元素只有 4 个,
应该是5个的,不知大家遇到这个问题没有。

-----------------------------------------------

这些是参考 JSK的文档

int[] executeBatch() throws SQLException 
将一批命令提交给数据库来执行,如果全部命令执行成功,则返回更新计数组成的数组。返回数组的 int 元素的排序对应于批中的命令,批中的命令根据被添加到批中的顺序排序。方法 executeBatch 返回的数组中的元素可能为以下元素之一: 
大于等于 0 的数 - 指示成功处理了命令,是给出执行命令所影响数据库中行数的更新计数 
SUCCESS_NO_INFO 的值 - 指示成功执行了命令,但受影响的行数是未知的 
如果批量更新中的命令之一无法正确执行,则此方法抛出 BatchUpdateException,并且 JDBC 驱动程序可能继续处理批处理中的剩余命令,也可能不执行。无论如何,驱动程序的行为必须与特定的 DBMS 一致,要么始终继续处理命令,要么永远不继续处理命令。如果驱动程序在某一次失败后继续进行处理,则 BatchUpdateException.getUpdateCounts 方法返回的数组将包含的元素与批中存在的命令一样多,并且其中至少有一个元素将为: 
EXECUTE_FAILED 的值 - 指示未能成功执行命令,仅当命令失败后驱动程序继续处理命令时出现 
在 Java 2 SDK, Standard Edition, 1.3 版中已经修改了可能的实现和返回值,以适应抛出 BatchUpdateException 对象后在批量更新中继续处理命令的选项。 
返回:包含批中每个命令的一个元素的更新计数所组成的数组。数组的元素根据将命令添加到批中的顺序排序。 
抛出:SQLException - 如果发生数据库访问错误,在已关闭的 Statement 上调用此方法,或者驱动程序不支持批量语句。如果未能正确执行发送到数据库的命令之一或者尝试返回结果集合,则抛出 BatchUpdateException(SQLException 的子类)。 

其中整形常量的值分别为: 
SUCCESS_NO_INFO -2 
EXECUTE_FAILED -3

------解决方案--------------------
回帖是一种美德!每天回帖即可获得 10 分可用分!
------解决方案--------------------
4个?5个把,你是不是调试时候看成int[4]了,就是5个
------解决方案--------------------
刚才试验了一下,应该不会有问题的!若是有一条数据没有没能插入成功就会报错的!你最好把exception catch一下,输出exception信息,若不可能有一条没能插入成功也不会看到!若不就把Connection的autoCommit设置为false,最后Connection.commit()提交,一次性插入!