JDBC的事务控制

 

JDBC的事务控制

Select @@tx_isolation查看系统的执行方式

set@@autocommit=1;时是自动提交。

当系统执行 set@@autocommit=0;时才是非自动提交

Start transaction;此时开始修改数据库表格;正确执行用commit提交。

Commit提交语句。Commit后面的语句将是下一事务:一个独立的工作单元(有一条或多条sql语句做成的)

只有当所有的事务全部执行成功才能完成,否则全部失败。

ACID四个属性

A.原子性

每个事务都是一个整体不可分割,只有全部完成才能成功否则全部失败(不会处于执行中间的状态);

C.一致性

保证相应的事务处于正确的状态。

I.  隔离性

通过加锁的方法来实现隔离级别(在执行期间与外部隔绝不会被外部看到执行只有执行完成后才可以被看到)。

D.持久性

       当事务执行正确时,会永久的保留的。

set@@artocommit=1;时是自动提交

个事务

Rollback回滚事务(回到修改之前的状态);

设置保存点savepoint s1;

回滚到保存点:rollback work to savepoint s1;

事务没有提交,只有当commit执行时才提交,提交后保存点之前的修改才可永久保留

在JDBC中用conn.setAutoCommit(0);修改系统非自动提交。

conn.commit();事务提交

conn.rollback();事务回滚

SavePoint sp=con.setSavePoint();设置保存点

Con.rollback(sp);返回保存点

Con.setTransactionIsolation();设计隔离级别

事物的隔离级别

脏读:读到的线程未提交的数据;(在修改未提交时就让另一个事务读取就是脏读)

不可重复读:在一个事物中读取同一个记录两次,获取数据不同

幻读:在一个事务中,读取到的记录数不同

隔离级别

脏读

不可重复读

幻读

读未提交 Read Uncommitted

ü   

 

 

读已提交 Read Committed

 

 

 

可重复读 Repeatable Read

 

 

 

可序列化 Serializable

 

 

 

实例:

public class TestTransaction {

 

       /**

        * @param args

        */

       public static void main(String[] args) {

              // TODO Auto-generated method stub

              Connection con=null;

              PreparedStatement pst=null;

              Savepoint sp=null;

              try {

                     con=JdbcUtil.getConnection();

                    

                     con.setAutoCommit(false);

                     con.setTransactionIsolation(Connection.TRANSACTION_REPEATABLE_READ);

                     String str="delete from student where id=3";

                     pst=con.prepareStatement(str);

                    

                     System.out.println("第一条sql语句。。");

                     pst.executeUpdate();

                     sp=con.setSavepoint();

                     System.out.println("第二条sql语句...");

                     str="insert into student(id,name) values(2,'ttt')";

                     pst=con.prepareStatement(str);

                     pst.executeUpdate();

                     con.commit();

                     System.out.println("事务完成...");

                    

                    

              } catch (SQLException e) {

                     // TODO Auto-generated catch block

                     e.printStackTrace();

                     try {

                            con.rollback(sp);

                            con.commit();

                     } catch (SQLException e1) {

                            // TODO Auto-generated catch block

                            e1.printStackTrace();

                     }

              }finally{

                     try {

                            con.setAutoCommit(true);

                     } catch (SQLException e) {

                            // TODO Auto-generated catch block

                            e.printStackTrace();

                     }

                     JdbcUtil.release(null,pst, con);

              }

             

       }

 }

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值