2012-02-15 99 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