2012-02-28 41 views
3

我有一个简单的触发器,它可以在创建或更新潜在客户时从引导对象中提取数据并将其放入自定义“Finance”对象中。出于某种原因,Trigger.new [i] .Id在插入前触发的触发器中返回NULL。插入之前的触发器不返回lead.Id

我要疯了,因为我看不到任何理由的Id是NULL ...这里是我的代码:

trigger FinanceNew on Lead (before insert) { 

Map<String,User> userList = new Map<String,User>{}; 

// Places each returned user into a map with their sfID as the key 
for(User tmp : [SELECT Id,Name,Email,Phone FROM User]){ 
    userList.put(tmp.Id,tmp); 
} 

for(integer i = 0; i<Trigger.new.size(); i++){ 

    string leadName = null; 

    if(Trigger.new[i].FirstName != ''){ 
     leadName = Trigger.new[i].FirstName + ' ' + Trigger.new[i].LastName; 
    }else{ 
     leadName = Trigger.new[i].LastName; 
    } 

    User ownerInfo = userList.get(Trigger.new[i].OwnerId); 

    ID leadId = Trigger.new[i].Id; // THIS IS RETURNING NULL!! 

    Finance__c financeRecord = new Finance__c(

     Name = leadName, 
     Lead__c = leadId, 
     Lead_Email__c = Trigger.new[i].Email, 
     Lead_Phone__c = Trigger.new[i].Phone, 
     Lead_Owner_Name__c = ownerInfo.Name, 
     Lead_Owner_Email__c = ownerInfo.Email, 
     Lead_Owner_Phone__c = ownerInfo.Phone 

    ); 

    insert financeRecord; 

    } 

} 

感谢您提前给任何帮助!

约什

回答

9

出于某种原因,该Trigger.new [I] .ID在插入前其触发触发器返回NULL。

SFDC记录在插入之前没有ID。插入过程创建ID。你可能想在插入后使用。

+0

我觉得像一个绝对的小丑。这正是问题所在。谢谢! – VictorKilo 2012-02-28 23:20:50