关于事务

 

 

public int delete(int sID) {

     dbc = new DataBaseConnection();
  Connection con = dbc.getConnection();
  try {
   con.setAutoCommit(false);// 更改JDBC事务的默认提交方式
   dbc.executeUpdate("delete from xiao where ID=" + sID);
   dbc.executeUpdate("delete from xiao_content where ID=" + sID);
   dbc.executeUpdate("delete from xiao_affix where bylawid=" + sID);
   con.commit();//提交JDBC事务
   con.setAutoCommit(true);// 恢复JDBC事务的默认提交方式
   dbc.close();
   return 1;
  }
  catch (Exception exc) {
   con.rollBack();//回滚JDBC事务
   exc.printStackTrace();
   dbc.close();
   return -1;
  }
}

 

这是JDBC提交事务的方式,有时间去学习下Hibernate的事务管理机制

 


try{
Session session = HibernateUtils.getSessionFactory().getCurrentSeesion();
seesion.beginTransation();

session.getTransact().commit();//提交事物

}catch(Exception e){
e.printStackTrace();
session.getTransaction().rollback();//回滚事物
}


getCurrentSession()与openSession()的区别

采用getCurrentSeesion()创建的session会绑定到当前线程中,而采用openSession(),创建的session则

不会

采用getCurrentSession()创建的session在commit或rollback时,会自动关闭,而采用openSession()创

建的session必须手动关闭

 



 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是几个关于Spring事务的面试题: 1. Spring事务的传播行为有哪些?它们的含义是什么? 答:Spring事务的传播行为包括REQUIRED、SUPPORTS、MANDATORY、REQUIRES_NEW、NOT_SUPPORTED、NEVER和NESTED。它们的含义如下: - REQUIRED:支持当前事务,如果当前没有事务,就新建一个事务。这是最常见的选择。 - SUPPORTS:支持当前事务,如果当前没有事务,就以非事务的方式执行。 - MANDATORY:支持当前事务,如果当前没有事务,就抛出异常。 - REQUIRES_NEW:新建事务,如果当前存在事务,把当前事务挂起。 - NOT_SUPPORTED:以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。 - NEVER:以非事务方式执行,如果当前存在事务,则抛出异常。 - NESTED:如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则新建一个事务。 2. Spring事务的隔离级别有哪些?它们的含义是什么? 答:Spring事务的隔离级别包括DEFAULT、READ_UNCOMMITTED、READ_COMMITTED、REPEATABLE_READ和SERIALIZABLE。它们的含义如下: - DEFAULT:使用数据库默认的隔离级别。 - READ_UNCOMMITTED:最低的隔离级别,允许读取未提交的数据,存在脏读、不可重复读、幻读等问题。 - READ_COMMITTED:允许读取已提交的数据,避免了脏读,但是仍然存在不可重复读和幻读问题。 - REPEATABLE_READ:保证同一事务中多次读取同一数据时,结果始终一致,避免了脏读和不可重复读,但是仍然存在幻读问题。 - SERIALIZABLE:最高的隔离级别,强制事务串行执行,避免了脏读、不可重复读和幻读,但是会影响并发性能。 3. Spring事务的实现方式有哪些? 答:Spring事务的实现方式包括编程式事务和声明式事务。编程式事务是通过编写代码实现事务控制,比较灵活,适用于复杂的事务场景。声明式事务是通过注解或XML配置实现事务控制,比较简单,适用于简单的事务场景。在实际开发中,通常使用声明式事务来实现事务控制。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值