Apex Trigger - 使用数据加载器时的值不正确

时间:2013-12-12 15:58:04

标签: triggers salesforce apex

我在帐户对象上有一个字段,在编辑帐户时会更新。单独编辑记录时,会将正确的值写入字段。当我使用数据加载器。 。 。一个值适用于所有记录。这是我的触发器,请指教。

trigger Populate_Transfer_Manager on Account (before insert, before Update) {   

    list<id> aid = new list<id>();
    for(account a: trigger.new){           
        aid.add(a.ownerid);
    }

list<user> managers = new list<user>();
    managers = [select managerid from user where id in: aid];


set<id> manid = new set<id>();                             
    for(user u: managers){
        manid.add(u.managerid);
    }


for(account a: trigger.new){        
    for(id i: manid){           
            a.transfer_manager__c = i;       
        }
    }
}

1 个答案:

答案 0 :(得分:0)

触发器仅针对每批200个触发一次,并将值分配给批处理中的所有记录。使用地图我能够为数据库中的所有记录分配正确的值。

trigger Populate_Transfer_Manager on Account (before insert, before Update) {    

    list<id> aid = new list<id>();
    for(account a: trigger.new){                   
        aid.add(a.ownerid);
            }
    map<id, user> users = new map<id, user>(
        [select managerid from user where id in: aid]);

    for(account a: trigger.new){
        a.Transfer_Manager__c = users.get(a.ownerid).managerid;
    }
}