问题出在不正确地使用了executeBatch
方法。在PostgreSQL中,executeBatch
方法并不支持批量执行SQL语句。相反,它只能用于执行一条预编译的SQL语句多次。
要解决这个问题,你可以将SQL语句拆分成单独的语句,并使用循环逐个执行它们。
以下是一个示例代码,演示如何按照mkyong指南执行多个SQL语句并提交更改:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public class Main {
public static void main(String[] args) {
String url = "jdbc:postgresql://localhost:5432/dbname";
String username = "username";
String password = "password";
try (Connection conn = DriverManager.getConnection(url, username, password)) {
String[] sqlStatements = {
"INSERT INTO table_name (column1, column2) VALUES ('value1', 'value2')",
"UPDATE table_name SET column1 = 'new_value' WHERE column2 = 'value'",
"DELETE FROM table_name WHERE column1 = 'value'"
};
conn.setAutoCommit(false); // 设置手动提交
for (String sql : sqlStatements) {
try (PreparedStatement pstmt = conn.prepareStatement(sql)) {
pstmt.executeUpdate();
} catch (SQLException e) {
conn.rollback(); // 回滚事务
e.printStackTrace();
}
}
conn.commit(); // 提交事务
} catch (SQLException e) {
e.printStackTrace();
}
}
}
在上面的示例中,我们使用了一个字符串数组来存储要执行的SQL语句。然后,我们使用循环逐个执行每个语句,并在发生异常时回滚事务。
最后,我们手动提交所有的更改。请确保在操作数据库之前,将url
,username
和password
替换为实际的数据库连接信息。
下一篇:按照MLA名称排序数据