高章伟
2023-03-02 e3c02c03dd2de442bbced87236f60a13a1cd154e
force-app/main/default/classes/UpdateInquiryFormConfirmationBatch.cls
@@ -2,11 +2,13 @@
* 更新产品咨询单
* 没有确认的,确认天数=今天-创建日----自动 batch
* 有确认的(存在最小日期) 确认天数=最小日期-创建日-----触发器
* ocm管理省中对应的GI,SP助理变化,产品咨询单也变
*/
global class UpdateInquiryFormConfirmationBatch implements Database.Batchable<sObject> {
    public String query;
    public String inqid;
    private BatchIF_Log__c iflog;
    private String stb_Flag;//20220614 WLIG-CER9NQ you
    global UpdateInquiryFormConfirmationBatch() {
        this.query = query;
@@ -16,6 +18,7 @@
        iflog.Log__c = 'UpdateInquiryFormConfirmationBatch start\n';
        iflog.ErrorLog__c = '';
        insert iflog;
        stb_Flag=System.label.SetPersonalTargetBatch_Flag;
    }
    global UpdateInquiryFormConfirmationBatch(String inqid) {
@@ -27,6 +30,7 @@
        iflog.Log__c = 'UpdateInquiryFormConfirmationBatch start\n';
        iflog.ErrorLog__c = '';
        insert iflog;
        stb_Flag=System.label.SetPersonalTargetBatch_Flag;
    }
    global Database.QueryLocator start(Database.BatchableContext BC) {
@@ -40,6 +44,21 @@
    global void execute(Database.BatchableContext BC, list<Inquiry_form__c> inquiryList) {
        system.debug('==='+inquiryList.size());
        updateTimeoutDays(inquiryList,iflog);
        //20220518 you SWAG-CBUB2W start
        Map<String, OCM_Management_Province__c> mpMap = new Map<String, OCM_Management_Province__c>();
        List<OCM_Management_Province__c> ocmList = [select id, Name, GI_assistant__c,SP_assistant__c from OCM_Management_Province__c];
        system.debug('==ocmList='+ocmList.size());
       // 取得OCSM管理省的GI,SP 助理
        for (OCM_Management_Province__c mp : ocmList) {
            mpMap.put(mp.Name, mp);
        }
         updateGISPAssistant(mpMap, iflog);
        //20220518 you SWAG-CBUB2W end
    }
    //确认天数赋值
    public static void updateTimeoutDays(List<Inquiry_form__c> inquiryList, BatchIF_Log__c iflog) {
        String dateToday = String.valueOf(Date.today());
        for(Inquiry_form__c inq:inquiryList){
            String crdate = String.valueOf(inq.CreateDate__c);
@@ -71,8 +90,41 @@
                indexCon ++ ;   
            } 
        }
    }
    }
    public static void updateGISPAssistant(Map<String, OCM_Management_Province__c> mpMap, BatchIF_Log__c iflog) {
         List<Inquiry_form__c> updateInquiryFormList =
            [select id, GI_assistant__c, SP_assistant__c,OCM_man_province_cus__c,IfGotoDepartment__c from Inquiry_form__c
        where (GI_assistant__c !=null or SP_assistant__c !=null)
        and IfGotoDepartment__c = false ]; //还没有转移科室的,说明助理还需要操作,这个时候如果ocsm助理改变,这边也跟着改变
        system.debug('==updateInquiryFormList='+updateInquiryFormList.size());
        for (Inquiry_form__c ifo : updateInquiryFormList) {
            system.debug('==mpMap='+mpMap+'==ifo.OCM_man_province_cus__c=='+ifo.OCM_man_province_cus__c);
            if(null!=mpMap && mpMap.containsKey(ifo.OCM_man_province_cus__c)){
               OCM_Management_Province__c omp = mpMap.get(ifo.OCM_man_province_cus__c);
                if (omp != null) {
                    if(ifo.GI_assistant__c != omp.GI_assistant__c){
                       ifo.GI_assistant__c = omp.GI_assistant__c;
                    }
                    if(ifo.SP_assistant__c != omp.SP_assistant__c){
                       ifo.SP_assistant__c = omp.SP_assistant__c;
                    }
                }
             }
        }
        Integer indexCon = 0;
        Database.SaveResult[] lsrUpdateInq = Database.update(updateInquiryFormList, false);
        for (Database.SaveResult lsrChild : lsrUpdateInq) {
            if (!lsrChild.isSuccess()) {
                iflog.Is_Error__c = 3;
                Database.Error emsg = lsrChild.getErrors()[0];
                iflog.ErrorLog__c += 'GI助理: ' + updateInquiryFormList.get(indexCon).GI_assistant__c + ' \n'
                                     +'SP助理: ' + updateInquiryFormList.get(indexCon).SP_assistant__c + ' \n'
                                     + 'InquiryFormID: ' + updateInquiryFormList.get(indexCon).Id + '\n ConLog:' + emsg.getMessage() + '\n';
            }
            indexCon ++ ;
        }
    }
    global void finish(Database.BatchableContext BC) {
        system.debug('=====iflog:' + iflog.id+'==='+iflog.ErrorLog__c);
@@ -100,6 +152,91 @@
                update iflog;
            }
        }
        //20220614 WLIG-CER9NQ you
        if (stb_Flag=='true') {
          Database.executeBatch(new SetPersonalTargetBatch(), 20);
        }
    }
    @TestVisible private static void test() {
        Integer i = 0;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;
        i++;//可以多写点
    }
}