java.sql.BatchUpdateException: Io 异常: Software caused connection abort: recv fai

本文记录了一次在使用Oracle数据库进行批量更新操作时遇到的异常情况,包括Software caused connection abort错误、关闭的连接异常及连接释放失败等问题,并详细展示了异常堆栈跟踪。
2012-07-26 10:35:40,085 ERROR com.sitech.core.architecture.log.logstat.format.AccessBatchSqlFormatter -
java.sql.BatchUpdateException: Io 异常: Software caused connection abort: recv failed
at oracle.jdbc.driver.DatabaseError.throwBatchUpdateException(DatabaseError.java:343)
at oracle.jdbc.driver.OraclePreparedStatement.executeBatch(OraclePreparedStatement.java:10656)
at org.apache.commons.dbcp.DelegatingStatement.executeBatch(DelegatingStatement.java:297)
at com.sitech.core.architecture.log.logstat.format.AccessBatchSqlFormatter.write(AccessBatchSqlFormatter.java:72)
at com.sitech.core.architecture.log.logstat.thread.InfoWriter.run(InfoWriter.java:49)
at EDU.oswego.cs.dl.util.concurrent.PooledExecutor$Worker.run(PooledExecutor.java:748)
at java.lang.Thread.run(Thread.java:619)
2012-07-26 10:35:40,086 ERROR com.sitech.core.architecture.log.logstat.format.AccessBatchSqlFormatter -
java.sql.SQLException: 关闭的连接
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:146)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:208)
at oracle.jdbc.driver.PhysicalConnection.rollback(PhysicalConnection.java:1133)
at org.apache.commons.dbcp.DelegatingConnection.rollback(DelegatingConnection.java:328)
at org.apache.commons.dbcp.PoolingDataSource$PoolGuardConnectionWrapper.rollback(PoolingDataSource.java:312)
at com.sitech.core.architecture.log.logstat.format.AccessBatchSqlFormatter.write(AccessBatchSqlFormatter.java:85)
at com.sitech.core.architecture.log.logstat.thread.InfoWriter.run(InfoWriter.java:49)
at EDU.oswego.cs.dl.util.concurrent.PooledExecutor$Worker.run(PooledExecutor.java:748)
at java.lang.Thread.run(Thread.java:619)
2012-07-26 10:35:40,087 ERROR com.sitech.core.architecture.log.logstat.format.AccessBatchSqlFormatter - 连接释放失败
java.sql.SQLException: Already closed.
at org.apache.commons.dbcp.PoolableConnection.close(PoolableConnection.java:84)
at org.apache.commons.dbcp.PoolingDataSource$PoolGuardConnectionWrapper.close(PoolingDataSource.java:181)
at com.sitech.core.architecture.log.logstat.format.AccessBatchSqlFormatter.write(AccessBatchSqlFormatter.java:98)
at com.sitech.core.architecture.log.logstat.thread.InfoWriter.run(InfoWriter.java:49)
at EDU.oswego.cs.dl.util.concurrent.PooledExecutor$Worker.run(PooledExecutor.java:748)
at java.lang.Thread.run(Thread.java:619)
当遇到 `java.sql.BatchUpdateException: Violate unique constraint on` 异常,即违反唯一约束导致的该异常时,可参考以下解决方法: ### 检查数据唯一性 在插入数据之前,先对要插入的数据进行唯一性检查,避免插入重复的数据。可以在代码中编写逻辑,查询数据库中是否已经存在相同唯一键的数据,如果存在则进行相应处理,如跳过该条数据或更新已有数据。 ### 数据库层面处理 可以在数据库中创建唯一索引或唯一约束时,考虑使用 `IGNORE` 关键字(部分数据库支持)。当插入重复数据时,数据库会忽略这些重复插入操作,而不会抛出异常。例如在 MySQL 中可以使用 `INSERT IGNORE INTO` 语句。 ### 捕获异常并处理 在代码中捕获 `java.sql.BatchUpdateException` 异常,通过 `getNextException` 方法获取具体的异常原因,根据不同的原因进行相应处理。对于违反唯一约束的情况,可以跳过重复数据继续插入其他数据。示例代码如下: ```java import java.sql.BatchUpdateException; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; public class BatchInsertExample { public static void main(String[] args) { String url = "jdbc:mysql://localhost:3306/yourdatabase"; String user = "youruser"; String password = "yourpassword"; try (Connection connection = DriverManager.getConnection(url, user, password)) { String sql = "INSERT INTO yourtable (id, column1, column2) VALUES (?,?,?)"; try (PreparedStatement preparedStatement = connection.prepareStatement(sql)) { // 模拟批量插入数据 for (int i = 0; i < 10; i++) { preparedStatement.setInt(1, i); preparedStatement.setString(2, "value" + i); preparedStatement.setString(3, "value" + i); preparedStatement.addBatch(); } try { preparedStatement.executeBatch(); } catch (BatchUpdateException e) { java.sql.SQLException nextException = e.getNextException(); if (nextException.getMessage().contains("Duplicate entry")) { // 处理违反唯一约束的情况,如跳过重复数据 System.out.println("Duplicate data found, skipping..."); } else { nextException.printStackTrace(); } } } } catch (SQLException e) { e.printStackTrace(); } } } ``` ### 调整业务逻辑 重新审视业务逻辑,确认是否真的需要插入重复数据。如果不需要,可以在业务层进行数据去重处理,确保插入的数据是唯一的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值