Trigger 中的错误处理

在 Trigger 中,我们可以为进行操作的数据进行验证,类似于验证规则。如果遇到不符合条件的数据,可以通过 addError() 函数来将错误显示给用户,并记录日志。

在如下代码中,当一个“业务机会”对象被插入或更新之前,系统会检查“金额”字段的值是否不小于1000。如果“金额”的数值小于1000,该“业务机会”记录将不能被插入或更新。

错误信息的显示适用于前端和后端:

  • 如果该记录是从用户页面修改的,则用户会看到错误信息
  • 如果该记录是从 Apex 程序中被插入或修改,则错误信息会被记录在日志中
    trigger OppyMaxAmountTrigger on Opportunity (before insert, before update) {
    for(Opportunity opp : Trigger.New) {
    if(opp.amount < 1000) {
    opp.addError('Amount should not be less than 1000!');
    }
    }
    }

     Apex 例如如果在批量处理的过程中 出现的某一条Error处理方式:

  •     public class LvOrderBy {
    public string fieldNameOrPath {set;get;}
    public string nullsPosition {set;get;}
    public string sortDirection {set;get;}
    private string nullsPosSOQL() {
    // Name ASC NULLS FIRST, Id ASC NULLS FIRST",
    if (nullsPosition!=null && nullsPosition!='') {
    if ('first'.equalsIgnoreCase(nullsPosition)) {
    return ' NULLS FIRST ';
    } else if ('last'.equalsIgnoreCase(nullsPosition)) {
    return ' NULLS LAST ';
    } else {
    throw new A('Invalid nullsPosition.[' + fieldNameOrPath + '], must be \'first\' or \'last\'');
    }
    } else {
    return '';
    }
    }

      

    public class A  extends Exception  {
    
    	// 使用object类型作为参数,将其序列化作为message,
    // 方便与前段JS通信(JS可以解析message,从而细化错误消息)
    public A(object msg) {
    this.setMessage(JSON.serialize(msg));
    } }

      

例子:批量更新一批数据,其中个别数据是由validation 限制的,其余的都可以正常update,那么问题来了

1. 如何正常更新正确的数据;

2.如何正常更新正确的数据,并且log能获取到哪条失败的数据;

3.当其中有不满足条件的就全部不更新;

4.当其中有不满足条件的就全部不更新,并且页面提示错误;

第一种情况:直接update goods;

这种属于第二种情况;

for(Goods__c god : goods){
       god.GoodsDescribe__c = 'Nice2';
}
try{
update goods;
}
catch(Exception ex){
// system.debug(ex.getMessage());
}

这种属于第四种情况

for(Goods__c god : goods){
god.GoodsDescribe__c = 'Nice2';
}
try{
update goods;
}
catch(Exception ex){ // throw new MM(ex.getMessage());
}

  public class MM extends Exception {
  // 使用object类型作为参数,将其序列化作为message,
  // 方便与前段JS通信(JS可以解析message,从而细化错误消息)
    public MM(object msg) {
      this.setMessage(JSON.serialize(msg));
    }
  }

Visualforce Error
MM: "Update failed. First exception on row 2 with id a007F000001FDheQAG; first error: FIELD_CUSTOM_VALIDATION_EXCEPTION, this is englist: [GoodsDescribe__c]"
Error is in expression '{!Doit}' in component <apex:commandButton> in page guoqingpage: Class.Controller.Doit: line 20, column 1

第三种情况邮件提醒:
如果换成  sendEmail(ex.getMessage());

public void sendEmail(String Msg){
// Send Email to Admin
Messaging.SingleEmailMessage message = new Messaging.SingleEmailMessage();
message.setToAddresses(new String[] { 'guang@%%.com' });
message.setSubject('Group Upsert');
message.sethtmlBody('Error:'+Msg);
Messaging.sendEmail(new Messaging.Email[] {message});
}


assertEquals的用法:
Goods__c a = new Goods__c();
a.Name = 'testScheduledApexFromTestMethod';
insert a; System.assertEquals('testScheduledApexFromTestMethod1',
[SELECT Id, Name FROM Goods__c WHERE Id = :a.Id].Name);

  

Database.upsert(goods,false); 这种写法可以忽悠掉错误的数据而不终止insert,正常的数据还是可以插入的,忽略错误的;

对Database.insert(List<SObject> sobjects, allOrNothing)方法中第二个参数的认识:

如果allOrNothing为false表示允许部分insert成功,如果true表示一有失败全部操作失败,项目中多用false。

实例:

List<Account> accList = new List<Account>{

    new Account(Name='ttt'),

    new Account()

};

Database.SaveResult[] srList = Database.insert(accList, false);

for(Database.SaveResult sr : srList) {

    if (!sr.isSuccess()) {

        // Operation failed, so get all errors                

        for(Database.Error err : sr.getErrors()) {

            System.debug('The following error has occurred.');                    

            System.debug(err.getStatusCode() + ': ' + err.getMessage());

            System.debug('Fields that affected this error: ' + err.getFields());

        }

    }

}

System.DmlException: Update failed. First exception on row 0 with id 0051s000002aFxUAAU;
first error: MIXED_DML_OPERATION, DML operation on setup object is not permitted after you have updated a non-setup object (or vice versa): User, original object: BatchStatus__c: []

https://www.javaniceday.com/post/mixed_dml_operation-error-and-apex-unit-tests-how-to-fix-it-#title4

https://blog.csdn.net/qq_38261445/article/details/104236604:

简单说就是不能在一个事务中又更新case 又更新User;

061_Apex 异常捕捉的更多相关文章

  1. 基础知识《十》java 异常捕捉 ( try catch finally ) 你真的掌握了吗?

    本文转载自  java 异常捕捉 ( try catch finally ) 你真的掌握了吗? 前言:java 中的异常处理机制你真的理解了吗?掌握了吗?catch 体里遇到 return 是怎么处理 ...

  2. Java多线程——<七>多线程的异常捕捉

    一.概述 为什么要单独讲多线程的异常捕捉呢?先看个例子: public class ThreadException implements Runnable{ @Override public void ...

  3. Oracle- 存储过程和异常捕捉

    这段时间晚上有时候去打打球,回家看看电视剧,日子一天天过…….学了点ORACLE存储过程基础,作一下备注,以便日后需查阅. 创建无参存储过程 create procedure p_myPro1 is ...

  4. php错误及异常捕捉

    原文:php错误及异常捕捉 在实际开发中,错误及异常捕捉仅仅靠try{}catch()是远远不够的. 所以引用以下几中函数. a)   set_error_handler 一般用于捕捉  E_NOTI ...

  5. android中全局异常捕捉

    android中全局异常捕捉 只要写代码就会有bug,但是我们要想办法收集到客户的bug.有第三方bugly或者友盟等可以收集.但是,android原生就提供了有关收集异常的api,所以我们来学习一下 ...

  6. [iOS]异常捕捉

    UncaughtExceptionHandler.h #import <Foundation/Foundation.h> NS_ASSUME_NONNULL_BEGIN @interfac ...

  7. Spring 全局异常捕捉

    Spring全局异常捕捉类 注解@ControllerAdvice package com.sicdt.sicsign.web.bill.controller; import org.springfr ...

  8. 5.全局异常捕捉【从零开始学Spring Boot】

    在一个项目中的异常我们我们都会统一进行处理的,那么如何进行统一进行处理呢? 新建一个类GlobalDefaultExceptionHandler, 在class注解上@ControllerAdvice ...

  9. springboot(四)拦截器和全局异常捕捉

    github代码:https://github.com/showkawa/springBoot_2017/tree/master/spb-demo/spb-brian-query-service 全部 ...

  10. SQL Server Try Catch 异常捕捉

    SQL Server Try Catch 异常捕捉 背景 今天遇到一个关于try catch 使用比较有意思的问题.如下一段代码: SELECT @@TRANCOUNT AS A BEGIN TRY ...

随机推荐

  1. Linux网络第四章:SSH远程管理及通过SSH实现服务器之间的免密连接

    目录 一.SSH远程管理基础 1.ssh协议 2.ssh原理 3.配置文件解析 4.登录方法 5.使用ssh协议传输的命令 二.免密连接的实现 1.免密连接原理 2.免密实现环境准备 3.在客户端生成 ...

  2. java8 stream 常用操作

    遍历 // list 遍历,stream() 可省略 list.stream().forEach(e -> { }); // map 遍历 map.forEach((k,v) -> { } ...

  3. 使用async实现多个请求并发

    // 写法一 let [cache, cache2] = await Promise.all([cachePromise, cachePromise2]); // 写法二 let Promise= c ...

  4. 推荐2个可用于毕设的微信小程序

    智能垃圾回收小程序 下载: http://market.zhenzikj.com/detail/103.html 2. 通用答题小程序 下载http://market.zhenzikj.com/det ...

  5. openssl常用操作

    参考:https://www.golinuxcloud.com/openssl-view-certificate/ 查看证书信息 openssl x509 -in server.crt -text - ...

  6. 使用IntelliJ创建第一个简单的Springboot项目

    使用Intellij创建Springboot项目 使用IntelliJ创建Springboot项目是非常方便的,创建过程中,我们可以自由的选择要启用的springboot生态里的各种框架.插件.本文只 ...

  7. linux升级系统内核版导致死锁

    如上图片,官方说明为linux内核版本过低,存在系统bug,具体说明如下: https://baijiahao.baidu.com/s?id=1652492237858209875&wfr=s ...

  8. C# VS2019修改工程名

    1.修改解决方案的名称:选择解决方案的名称,右键重命名即可 2.修改项目名称,方法同上,不再赘述 3.修改项目的程序集名称和默认命名空间:选择项目,右键属性,弹出如下对话框 4.替换项目或解决方案中的 ...

  9. locust中的监听器

    locust的master相关的几个监听器: 心跳监听器: 一个while循环,不断判断所有client当前的心跳状况,如果有一个client失去了心跳,就打印了一个警告日志,如果所有client都失 ...

  10. node_modules修改?

    1.直接改node_modules的内容..... 但是下次npm i之后那个包的代码又恢复原状 2.独立维护需要改的包 把需要改的包复制下来,修改,推送到npm上. 项目里用新包即可,但是增加了维护 ...