2015-11-06 61 views
0


我正在读取大量数据并希望将它们插入数据库中。到目前为止,没有什么大不了的,一切工作都正常,使用准备好的声明并且为每一行发射。
现在我切换到批处理获得更好的性能,并得到一个错误:
java.sql.SQLException: Fehler bei Stapelverarbeitung aufgetreten: batch must be either executed or cleared
我发现SO有关此特定错误的唯一信息就是这个问题dealing with different types of sql stements for one batch
然而,这不是我在做什么,下面的代码:
Java&SQL - 批处理必须执行或清除批处理时出错

@Override 
    public void addRow(String[] row) throws SQLException, ClassNotFoundException, IOException { 
     PreparedStatement s = q.getStatement(); 
     for (int i = 0; i < row.length; i++) { 
      s.setString(i + 1, row[i]); 
     } 
     s.addBatch(); 

    } 

    @Override 
    public void done() { 
     try { 
      DatabaseUtils.execute(q); //Error is thrown here! 
     } catch (Exception e) { 
      e.printStackTrace(); 
     } 
    } 


其他信息:q是用于预处理语句简单的包装,其allwos我更容易,第一getStatement()调用之后没有再加载它声明的更改是可能的。该陈述是一个简单的INSERT,如INSERT INTO TABLE1 VALUES (?, ?, ?, ?)
DatabaseUtils.execute没有别的作为query.getStatement().execute();
数据库是一个Oracle数据库V10.205,JDK 1.6',驱动程序是ojdbc6
有人可以请解释为什么错误被抛出?

回答

1

我相信

DatabaseUtils.execute does nothing else as query.getStatement().execute();

是这里的问题。尝试将其更改为query.getStatement().executeBatch()或创建一个新方法DatabaseUtils.executeBatch即可。