2012-02-15 94 views
1

我有一個場景,當合約結束日期是今天時,我需要克隆機會及其lineitems。 opp訂單項的字段名爲Product_Family_ c。我將不得不克隆其每月的線性更新類型爲 _c的opp。 我被困在如何克隆oli項目並將新的oppty id分配給oli項目。在salesforce中以編程方式克隆機會及其線性

todays=date.today(); 
    system.debug('todays'+todays);  
    for(opportunity o:[select Auto_Renew__c,Contract_lenght_in_months__c,Contract_End_Date__c,id from opportunity where Auto_Renew__c='Yes' and Contract_End_Date__c =:todays ]) 
    { 
     SetOppId.add(o.id); 
     MapOpp.put(o.id,o); 
    } 
    system.debug('SetOppId'+SetOppId); 
    system.debug('MapOpp'+MapOpp); 
    for(OpportunityLineItem oli:[select OpportunityId from OpportunityLineItem where Product_Family__c='Monthly' and OpportunityId in :SetOppId]) 
    { 
     SetOppIdtoRenew.add(oli.OpportunityId); 
     Mapoli.put(oli.id,oli); 

    } 
    system.debug('SetOppIdtoRenew'+SetOppIdtoRenew); 
    for(id a:SetOppIdtoRenew) 
    { 
     //MapOpp.get(a).Contract_End_Date__c=MapOpp.get(a).Contract_End_Date__c.addDays(1); 
     //MapOpp.get(a).Contract_End_Date__c=MapOpp.get(a).Contract_End_Date__c.addMonths(integer.valueof(MapOpp.get(a).Contract_lenght_in_months__c)); 
     Lstopp.add(new opportunity(name=MapOpp.get(a).name+' renewal '+string.valueof(date.today()), 
           Contract_lenght_in_months__c=MapOpp.get(a).Contract_lenght_in_months__c, 
           Contract_End_Date__c=MapOpp.get(a).Contract_End_Date__c.addMonths(integer.valueof(MapOpp.get(a).Contract_lenght_in_months__c))+1, 
           StageName=MapOpp.get(a).StageName, 
           CloseDate=MapOpp.get(a).CloseDate 
          // ,<fieldname>=MapOpp.get(a).<fieldname>... for all the fields you ned to copy over 
           )); 

    } 
    system.debug('Lstopp'+Lstopp); 
    insert Lstopp; 

回答

1

你在朝着正確的方向思考。但是,在將OppID分配給訂單項之前,您必須插入商機。我想象這種破壞你的事務控制,但你總是可以使用數據庫保存點來使整個操作成爲原子。

例如:

SavePoint sp = Database.setSavepoint(); 
    try { 
     upsert newOpportunities; 
     // now create line items and assign IDs 
    } 
    catch (Exception ex) { 
     Database.rollback(sp);  
     // cleanup 
    } 

爲了老機會映射到新的,你需要一個Map<ID, Opportunity>和列表,並能夠在映射的方式重新使用新的ID相同的新機遇,EB填補他們(我用的僞代碼,如果你有麻煩解釋它,讓我知道)

foreach(oldopp) { 
    newopp = clone oldopp; 
    list.add(newopp); 
    map.put(oldopp.id, newopp); 
} 
upsert list; 
// now we have new oppids for cloned items, use them to map 

foreach(oldlineitem) { 
    newlineitem = clone oldlineitem; 
    newlineitem.OpportunityId = map.get(oldlineitem.OpportunityId).Id; 
    ... 
} 
upsert listofnewlineitems; 

}

+0

MMIX,我被困點在哪裏我可以插入的機會,但沒有t確定我可以如何將這個新的opp映射到克隆的oppline項目 – Prady 2012-02-16 05:02:24

+0

單個對象實例添加到botha列表和地圖仍然是同一個對象。我會更新答案 – mmix 2012-02-16 07:26:41

+0

oh gr8 !! ..這很有道理:) – Prady 2012-02-16 10:52:46