Java & SQL - 批处理时出错,必须执行或清除批处理
Java & SQL - Error when batch processing, batch must be either executed or cleared
我正在阅读大量数据并想将它们插入数据库中。到目前为止,没什么大不了的,使用准备好的语句并为每一行触发它,一切都运行良好。
现在我切换到批处理以获得更好的性能并得到一个错误:
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 (?, ?, ?, ?)
DatabaseUtils.execute 不做任何其他事情,如 query.getStatement().execute();
.
数据库是 Oracle Database V10.205,JDK 1.6´,驱动程序是 ojdbc6
谁能解释一下为什么会抛出错误?
我相信
DatabaseUtils.execute
does nothing else as
query.getStatement().execute();
问题出在这里。尝试将其更改为 query.getStatement().executeBatch()
或创建一个新方法 DatabaseUtils.executeBatch
来做到这一点。
我正在阅读大量数据并想将它们插入数据库中。到目前为止,没什么大不了的,使用准备好的语句并为每一行触发它,一切都运行良好。
现在我切换到批处理以获得更好的性能并得到一个错误:
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 (?, ?, ?, ?)
DatabaseUtils.execute 不做任何其他事情,如 query.getStatement().execute();
.
数据库是 Oracle Database V10.205,JDK 1.6´,驱动程序是 ojdbc6
谁能解释一下为什么会抛出错误?
我相信
DatabaseUtils.execute
does nothing else asquery.getStatement().execute();
问题出在这里。尝试将其更改为 query.getStatement().executeBatch()
或创建一个新方法 DatabaseUtils.executeBatch
来做到这一点。