[Salesforce] 关于Trigger 的使用(防止死循环)

 因为帮同事做个EE, 考虑到的方法有两种, 第一是在接口上弄, 第二就是在trigger上做文章.

第一种方法风险比较大, 所以考虑第二种. 这种在trigger里面 insert or update 该 object 的做法. 

之前还没试过, 所以想到的问题是 会不会插数据进去的时候, 触发trigger, 然后执行到insert 这句的sihou,又继续递归下去?

在SF群中, 众人有不同的意见, 在help中也找不到相关的信息, 所以只能自己去尝试看看.

Trigger Tri_test on A(before insert, before update){
  A a1 = new A(name='aa');
  insert a1;
}
在A object 中, 加上上述的trigger, 然后用Dataloader 插入一条数据, 或者可以在console insert 一条. 然后就会碰到了这样的错误提示.

Tri_Test: execution of BeforeInsertcaused by: System.DmlException: Insert failed. First exception on row 0; first error: CANNOT_INSERT_UPDATE_ACTIVATE_ENTITY, Tri_Test: maximum trigger depth exceeded

说明了trigger 里面如果不加什么限制dml的条件, 直接insert 或 update 该 trigger 所在对象的记录的话, 会造成递归, 直到出发限制.

你可能感兴趣的:(Salesforce技术)