首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Java & SQL -批处理时出错,必须执行批处理或清除批处理

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

Stack Overflow用户
提问于 2015-11-06 14:48:19
回答 1查看 1.7K关注 0票数 0

我正在读取大量数据,并希望将它们嵌入到数据库中。到目前为止,没有什么大不了的,所有的事情都很好,使用一份准备好的声明,并在每一行都使用它。

现在,为了获得更好的性能,我切换到批处理,并得到了一个错误:

java.sql.SQLException: Fehler bei Stapelverarbeitung aufgetreten: batch must be either executed or cleared

我在上面找到的关于这个特定错误的唯一信息就是这个问题dealing with different types of sql stements for one batch

然而,这不是我要做的,下面是代码:

代码语言:javascript
复制
    @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 INTO TABLE1 VALUES (?, ?, ?, ?)

DatabaseUtils.execute除了query.getStatement().execute();什么也不做。

数据库是OracleDatabaseV10.205,JDK1.6‘,驱动程序是ojdbc6

有人能解释一下为什么会抛出错误吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-11-06 15:31:59

我相信

DatabaseUtils.execute除了query.getStatement().execute();什么也不做

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

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33569411

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档