我在更新触发器之后创建了以下内容,但是我无法保存它,我不太清楚为什么它不能工作
trigger Adhoc_Approval_process_trigger on Ad_Hoc_Approval__c (after update) {
list<Ad_Hoc_Approval__c> ladh= new list<Ad_Hoc_Approval__c>();
list<Ad_Hoc_Approval__c> query=[select Status__c,Submitted_for_Approval_Date__c from Ad_Hoc_Approval__c];
for(Ad_Hoc_Approval__c adh : query)
{
if(adh.Status__c =='Submitted for Approval')
{
adh.Submitted_for_Approval_Date__c=Date.today();
ladh.add(adh);
}
}
update ladh;
}我也把它转换成了一个预置更新触发器,它工作得很好,谁能帮我理解一下原因吗,
trigger Adhoc_Approval_process_trigger on Ad_Hoc_Approval__c (before update) {
for(Ad_Hoc_Approval__c adh : trigger.new)
{
if(adh.Status__c =='Submitted for Approval')
{
adh.Submitted_for_Approval_Date__c=Date.today();
}
}
}非常感谢
发布于 2017-10-05 08:29:54
你的意思是因为它没有编译而无法保存?嗯,看上去不错,有什么差错吗?
您的第一个版本将是一个永无止境的循环:)更新->更新->更新.更不用说查询没有WHERE子句,所以一旦达到10,0001条记录,它最终会爆炸.
第二个版本要好得多:)只对当前触发器的作用域和“更新前”免费保存到数据库。
https://stackoverflow.com/questions/46580660
复制相似问题