课程表

Apex课程

工具箱
速查手册

Apex - 触发器

当前位置:免费教程 » 程序设计 » Apex

Apex触发器类似于当特定事件发生时执行的存储过程。 它在记录事件发生之前和之后执行。

语法

  1. trigger triggerName on ObjectName (trigger_events) { Trigger_code_block }

执行触发器

以下是我们可以触发触发器的事件:

  • insert
  • update
  • delete
  • merge
  • upsert
  • undelete


触发器示例1

假设我们收到业务要求,当客户的“客户状态”字段从非活动状态更改为活动状态时,我们需要创建发票记录。 为此,我们将通过以下步骤在APEX_Customer__c对象上创建触发器:


第1步:进入sObject


第2步:点击客户


第3步:点击触发器相关列表中的“新建”按钮,添加如下所示的触发代码。

  1. //Trigger Code
  2. trigger Customer_After_Insert on APEX_Customer__c (after update) {
  3. List InvoiceList = new List();
  4. for (APEX_Customer__c objCustomer: Trigger.new) {
  5. if (objCustomer.APEX_Customer_Status__c == 'Active') {
  6. APEX_Invoice__c objInvoice = new APEX_Invoice__c();
  7. objInvoice.APEX_Status__c = 'Pending';
  8. InvoiceList.add(objInvoice);
  9. }
  10. }
  11. //DML to insert the Invoice List in SFDC
  12. insert InvoiceList;
  13. }

说明:

Trigger.new:这这是上下文变量,用于存储当前正在插入或更新的触发器上下文中的记录。 在这种情况下,此变量具有已更新的Customer对象的记录。


还有上下文中可用的其他上下文变量:trigger.old,trigger.newMap,trigger.OldMap。

触发器示例2

当对客户记录进行更新操作时,将执行上述触发器。 但是,假设我们希望仅在客户状态从非活动更改为活动而不是每次都更改时插入发票记录。

为此,我们可以使用另一个上下文变量trigger.oldMap,它将密钥作为记录id和值存储为旧记录值。

  1. //Modified Trigger Code
  2. trigger Customer_After_Insert on APEX_Customer__c (after update) {
  3. List<apex_invoice__c> InvoiceList = new List<apex_invoice__c>();
  4. for (APEX_Customer__c objCustomer: Trigger.new) {
  5. //condition to check the old value and new value
  6. if (objCustomer.APEX_Customer_Status__c == 'Active' && trigger.oldMap.get(objCustomer.id).APEX_Customer_Status__c == 'Inactive') {
  7. APEX_Invoice__c objInvoice = new APEX_Invoice__c();
  8. objInvoice.APEX_Status__c = 'Pending';
  9. InvoiceList.add(objInvoice);
  10. }
  11. }
  12.  
  13. //DML to insert the Invoice List in SFDC
  14. insert InvoiceList;
  15. }

示例:

我们使用Trigger.oldMap变量,如前所述,它是一个上下文变量,用于存储正在更新的记录的Id和旧值。

转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号