• Hibernate学习笔记四:事务管理


    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6768298.html 

    一:需要事务的Session操作

        Session操作中,查询类操作是不需要事务就能生效的,如get、query等。

        而save、update、delete等操作,则需要提交事务才能生效。

    二:DAO层事务管理的缺点

        DAO层主要负责数据的持久化操作,因此,也是session操作的主要位置。我们一般在DAO层针对一个表定义增删查改操作的方法,一个方法一个功能。因此,如果在DAO进行事务管理的话,就要每个方法  开启事务——session操作——提交事务——关闭session,这会产生大量重复代码,并且不灵活,如:懒加载(var=session.load(POJO))时,查询变量var在被调用时,才会触发SQL语句进行数据库查询,而在此之前session不能被关闭。如果这个变量被发布出去,如:return到service层,那我们只能在service层关闭session了,这样又要考虑session的传递问题,十分麻烦。

    三:一般的事务管理策略

        在service中定义事务,是最正确的方式。因为一个service层方法对应着一个业务,一个业务中可能有多个数据操作,因此我们“以业务为单位进行事务管理”。

       

    四:懒加载事务管理

        用懒加载查询得到的变量,如果发布到了其他层使用,那么事务管理、session关闭都要随之迁移。既然如此,我们干脆就在“唯一入口和出口”处进行事务管理与session的开启关闭,那就是——Filter。    

    public void doFilter(ServletRequest request, ServletResponse response,
                FilterChain chain) throws IOException, ServletException {
            Transaction tx = null;        
            try {
                Session session  = HibernateSessionFactory.getSession();
                tx = session.beginTransaction();
                chain.doFilter(request, response);//传递进去,经历各层处理、View层响应
                tx.commit();
            } catch (Exception e) {
                if (tx!=null&tx.isActive()) {//如果Transcation依旧存在,即系出现异常,回滚事务   
                    tx.rollback();
                }
            } finally{
                session.close();
            }
        }
  • 相关阅读:
    NFS+DHCP+TFTP无人值守安装linux
    systemverilog学习(6)并发进程与内部通信
    systemverilog学习(5)procedural statement ,task ,function&automatic
    systemverilog学习(4)动态数组
    systemverilog学习(3)基本数据类型
    systemverilog学习(2)interface
    systemverilog学习(1)基础
    Verilog学习(13)PLL与搜索代码
    Verilog学习(12)实战之强度与竞争
    verilog学习(11)实战之计数器
  • 原文地址:https://www.cnblogs.com/ygj0930/p/6768298.html
Copyright © 2020-2023  润新知