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. docker容器部署flask单页面应用

    本地安装docker,拉取centos镜像. docker pull centos:7 本地文件结构: /usr/local/var/tmp/docker_demo .app ---requireme ...

  2. [人脸识别]01-python环境准备-安装opencv

    安装opencv pip install opencv-python pip install  matplotlib pip install opencv-contrib-python --user

  3. 12组-Beta冲刺-总结

    组长博客链接 https://www.cnblogs.com/147258369k/p/15615820.html 一.基本情况 1.1 现场答辩总结 柯老师意见: 面向普通用户群体推出排行榜功能 增 ...

  4. CSS的拾遗(1)

    CSS的拾遗(1) 1.padding: (1)定义:在一个声明中设置所有内边距属性 (2)用法: 例子 1:上,右,下,左 padding:10px 5px 15px 20px; 上内边距是 10p ...

  5. 【驱动 】frambuffer中显示屏参数的修改

    1.在x210板子的kernel中,默认LCD显示屏是800*400的,修改在 kernel/arch/arm/mach-s5pv210/mach-x210.c 中 258行 #define S5PV ...

  6. Linux环境下给python项目写个启停服务

    写个服务,写完后放在/lib/systemd/system路径下 update_rule.server [Unit] Description = TinyScan update rule [Servi ...

  7. php json_encode 斜杠 反斜杠 转义处理

    $data = str_replace("\\\\n", "\\n", \jsonEncode($data)); // \\n转为\n $data = str_ ...

  8. Cleanest XMaster绿色解压最新版下载9.6密钥激活码

    cad安装报错换了好几个版本都不行,用这个卸载了一下,确实有用 Cleanest XMaster绿色版cad卸载工具分享下载 地址一(百度网盘) 地址二(直接下载) 9.6.05密钥:[AtrXShX ...

  9. Vue 使用Lodop进行标签(条码)打印

    一.使用到的插件:vue-barcode(vue条形码插件),Lodop打印控件(我这里使用windows64版,所以以此进行举例说明.). 详述:前者(指vue-barcode)针对在前端界面上观察 ...

  10. iOS笔记 - Runtime 01:前期准备(isa结构 | Class结构 | 方法缓存)

    前言 1 - OC机制很多都是基于 Runtime实现的,比如指针的弱引用.OC的消息机制属于 Runtime的一部分 2 - OC是一门动态语言,在程序运行过程中就可以修改已经编译好的代码 3 -  ...