org.hibernate.resource.jdbc.internal.LogicalConnectionManagedImpl@10cf3d8 is closed。

描述:在使用hibernate操作数据库时报org.hibernate.resource.jdbc.internal.LogicalConnectionManagedImpl@10cf3d8 is closed。
启动程序后,首先执行了一个get,然后接着执行update是抛出上该异常。 
原因:
操作Transaction时使用了ThreadLocal.在beginTransaction时,将新的transaction   set到了ThreadLocal中。
由于在get时执行beginTransaction打开了一个事务,而未执行commitTransaction方法,导致事务未提交。
所以接下来的update时抛了异常。
解决方法:
get时不需要commit,所以不可以调用commitTransaction方法,单独写一个提交事务的方法,把ThreadLocal中的事务重置即可。
代码:
private static final ThreadLocal<Transaction> transactionThreadLocal = new ThreadLocal<Transaction>();


public static void beginTransaction() {  
        Transaction transaction = (Transaction) transactionThreadLocal.get();  
      
        try {  
         
            if (transaction == null) {  
                transaction = getSession().beginTransaction();  
                transactionThreadLocal.set(transaction);  
            }  
        } catch (HibernateException e)  {  
            throw new HibernateException(e);  
        }  
    }  
    


    public static void commitTransaction() {  
        Transaction transaction = (Transaction) transactionThreadLocal.get();  
         
        try {
            if (transaction != null) {  
                transaction.commit();  
            }  
            transactionThreadLocal.set(null);  
        } catch (HibernateException e) {  
            throw new HibernateException(e);  
        }  
    }


    public static void commitNullTransaction() {
Transaction transaction = (Transaction) transactionThreadLocal.get();  
        
        try {  
        if (transaction != null) {
         transactionThreadLocal.set(null); 
        }
        } catch (HibernateException e) {  
            throw new HibernateException(e);  
        }  
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值