Java& SQL - 批处理时出错,必须执行或清除批处理

时间:2015-11-06 14:48:19

标签: java sql oracle prepared-statement


我正在阅读大量数据,并希望将它们嵌入数据库中。到目前为止,并没有什么大不了的事情,并且使用准备好的声明并且每行都触发它,一切都正常。
现在我切换到批处理以获得更好的性能并出现错误:
     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这个问题 但是,这不是我正在做的,这是代码:

    @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是PreparedStatements的简单包装器,我可以在第一次getStatement()调用之后更轻松地加载它,不再对语句进行进一步更改。该语句是一个简单的INSERT,例如INSERT INTO TABLE1 VALUES (?, ?, ?, ?)
数据库.Utils.execute不执行任何其他操作query.getStatement().execute();
数据库是Oracle数据库V10.205,JDK 1.6',驱动程序是ojdbc6
有人可以解释一下为什么会抛出错误吗?

1 个答案:

答案 0 :(得分:1)

我相信

  

DatabaseUtils.execute不做任何其他事情   query.getStatement().execute();

是问题所在。尝试将其更改为query.getStatement().executeBatch()或创建一个可以执行此操作的新方法DatabaseUtils.executeBatch