日期:2014-05-16  浏览次数:20514 次

数据库事物处理
Hibernate SessionFactory中openSession和getCurrentSession方法的区别:
1. 前者打开一个新的,后者当前有session的话,则是使用当前的session,没有的话则创建一个新的;
2. 如果使用前者获得一个session的话,需要手动关闭session,使用后者,当事务提交,session会自动关闭,如果再关闭session则会报如下异常:Session has already closed;

事务边界声明
只要声明了一个事务,数据库系统就会自动保证事务的ACID特性。
    

      声明事务包含:

      事务的开始边界

      事务的正常结束边界(commit):提交事务,永久保存

      事务的异常结束边界(rollback):撤销事务,数据库回退到执行事务前的状态

    

     数据库支持两种事务模式:

      自动提交模式:每个SQL语句都是一个独立的事务,数据库执行完一条SQL语句后,会自动提交事务。

      手工提交模式:必须由数据库的客户程序显式指定事务的开始和结束边界

    

      JDBC Connection类的事务控制方法:

      setAutoCommit(boolean autoCommit) 设置是否自动提交事务,默认自动

      commit() 提交事务

      rollback() 撤销事务
Hibernate控制事务的方法:

     1. 调用sessionFactory不带参数的openSession方法,从连接池获得连接,Session自动把连接设为手工提交事务模式。

      Session   session = sessionFactory.openSession();

      若调用带connection参数的openSession,则需要自己设置手工提交:

      connection.setAutoCommit(false);

      Session   session = sessionFactory.openSession(connection);
      2. 声明事务的开始边界

      Transaction tx = session.beginTransaction();

      3. 提交事务

       tx.commit();

      4. 撤销事务:

       tx.rollback();

      一个session可以对应多个事务,但是应优先考虑让一个session只对应一个事务,当一个事务结束或撤销后,就关闭session.

     不管事务成功与否,最后都应调用session的close关闭session

      任何时候一个session只允许有一个未提交的事务,不能同时开始两个事务