java中使用savepoint,如何设置和回滚到保存点?(How to set & rollback to a savepoint ?)

如何设置和回滚到保存点?(How to set & rollback to a savepoint ?)

问题描述 (Problem Description)

如何在java中创建Savepoint和Rollback?

解决方案 (Solution)

以下示例使用Rollback方法连接到Rollback以前保存的SavePoint。import java.sql.*;

public class jdbcConn {

public static void main(String[] args) throws Exception {

Class.forName("org.apache.derby.jdbc.ClientDriver");

Connection con = DriverManager.getConnection(

"jdbc:derby://localhost:1527/testDb","name","pass");

Statement stmt = con.createStatement();

String query1 = "insert into emp values(5,'name','job')";

String query2 = "select * from emp";

con.setAutoCommit(false);

Savepoint spt1 = con.setSavepoint("svpt1");

stmt.execute(query1);

ResultSet rs = stmt.executeQuery(query2);

int no_of_rows = 0;

while (rs.next()) {

no_of_rows++;

}

System.out.println("rows before rollback statement = " + no_of_rows);

con.rollback(spt1);

con.commit();

no_of_rows = 0;

rs = stmt.executeQuery(query2);

while (rs.next()) {

no_of_rows++;

}

System.out.println("rows after rollback statement = " + no_of_rows);

}

}

结果 (Result)

上面的代码示例将产生以下结果。 结果可能会有所不同。rows before rollback statement = 4

rows after rollback statement = 3

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值