Hibernate大数据量操作解决方案

阅读了Hibernate的Reference之后,可以采用批量处理的方法,当插入的数据超过10000时,就flush session并且clear。

下面是一个测试method。

* 测试成批插入数据的事务处理,返回是否成功

      public   boolean  insertBatch( final  Object objPO)  {
          boolean  isSuccess  =   false ;
         Transaction transaction  =   null ;
         Session session  =  openSession();
          try   {
             transaction  =  session.beginTransaction();
              for  ( int  i  =   0 ; i  <   100000 ; i ++ )  {
                 session.save(objPO);
                  if  (i  %   50   ==   0 )  {
                     //  flush a batch of inserts and release memory
                     session.flush();
                     session.clear();
                 }
             }
             transaction.commit();
             logger.info( " transaction.wasCommitted: "
                      +  transaction.wasCommitted());
             isSuccess  =   true ;
         }   catch  (HibernateException ex)  {
              if  (transaction  !=   null )  {
                  try   {
                     transaction.rollback();
                     logger.error( " transaction.wasRolledBack: "
                              +  transaction.wasRolledBack());
                 }   catch  (HibernateException ex1)  {
                     logger.error(ex1.getMessage());
                     ex1.printStackTrace();
                }
             }
             logger.error( " Insert Batch PO Error: "   +  ex.getMessage());
             ex.printStackTrace();
         }   finally   {
              if  (transaction  !=   null )  {
                 transaction  =   null ;
             }
             session.close();
         }
          return  isSuccess;
     } 

这只是简单的测试,实际项目中遇到的问题,要比这个复杂得多。
这时候,我们可以让Spring来控制Transaction,自己来控制Hibernate的Session,随时更新数据。

首先,利用HibernateDaoSupport类来自定义个方法打开Session;

public Session openSession(){
	        
	        return getHibernateTemplate().getSessionFactory().openSession();
	        
	    }  

然后,用打开的Session处理你的数据;
protected void doBusiness(Session session) {

        while (true) {
            //do your business with the opening session        
            someMethod(session);
            session.flush();
            session.clear();
            logger.info("good job!");            
        }       
}

每做一次数据操作,就更新一次Session,这样可以保证每次数据操作都成功,否则就让Spring去控制它roll back吧。

最后,记得关闭Session。

Session session  =  openSession();
   doBusiness(session);
  
session.close();  // 关闭session


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值