Salesforce batch Database.Stateful方法

在salesforce的后台计算当中,我们经常会使用batch,但是,我们通常大量的情况下面,我们会使用batch当中的getquerylocator方法,来查询大数据量的数据集,然后,你这个数据集交给execute方法去处理,比如,insert,delete,update.。但是,我们通常,还有一部分工作,有的时候,我们只是希望,前面的batch把query出来的大数据集做以简单的运算,然后传值给后面的batch来继续处理,并且在execute中,我们没有任何的insert,delete,update式行为。这个时候,我们就会遇到对像为空的情况。那么,在这种情况下面,我们只需要让batch 多实现 一个Database.Stateful方法就可以做到了 


下面程序,当batch运行完以后,你的Summary在finish当中为0,


global class SummarizeAccountTotal implements 
    Database.Batchable<sObject>{

   global final String Query;
   global integer Summary;
  
   global SummarizeAccountTotal(String q){Query=q;
     Summary = 0;
   }

   global Database.QueryLocator start(Database.BatchableContext BC){
      return Database.getQueryLocator(query);
   }
   
   global void execute(
                Database.BatchableContext BC, 
                List<sObject> scope){
		Summary = 123;
		
   }

global void finish(Database.BatchableContext BC){
        System.debug(Summary);
   }
}



下面程序,在Finish程序当中,debug结果为123


global class SummarizeAccountTotal implements 
    Database.Batchable<sObject>, Database.Stateful{

   global final String Query;
   global integer Summary;
  
   global SummarizeAccountTotal(String q){Query=q;
     Summary = 0;
   }

   global Database.QueryLocator start(Database.BatchableContext BC){
      return Database.getQueryLocator(query);
   }
   
   global void execute(
                Database.BatchableContext BC, 
                List<sObject> scope){
		Summary = 123;
		
   }

global void finish(Database.BatchableContext BC){
        System.debug(Summary);
   }
}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值