回滚操作通常用于数据库操作,可以用来撤销之前的一组数据库更改操作。例如,在事务中执行一组更新操作,如果中途出现错误,则可以回滚到事务开始时的状态。
在 Java 中,可以使用 JDBC 中的 Connection 对象的 setAutoCommit 方法来管理事务,使用 commit 方法提交事务,使用 rollback 方法回滚事务。
下面是一个示例代码,假设有一个 updateEmployeeSalary 方法用来更新员工工资,在事务中执行该操作,如果更新失败,则回滚事务:
```java import java.sql.*;
public class RollbackExample { // JDBC 驱动名及数据库 URL static final String JDBC_DRIVER = "com.mysql.jdbc.Driver"; static final String DB_URL = "jdbc:mysql://localhost:3306/employee_db";
// 数据库的用户名与密码
static final String USER = "username";
static final String PASS = "password";
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
try {
// 注册 JDBC 驱动
Class.forName(JDBC_DRIVER);
// 打开连接
System.out.println("连接数据库...");
conn = DriverManager.getConnection(DB_URL, USER, PASS);
// 开启事务
conn.setAutoCommit(false);
// 执行更新操作
stmt = conn.createStatement();
String sql = "UPDATE employees SET salary = salary + 500 WHERE id = 1";
int rowsAffected = stmt.executeUpdate(sql);
System.out.println(rowsAffected + " 行记录受影响");
// 提交事务
conn.commit();
System.out.println("事务已