在 Exception class 中有成员变量

Having member variable in Exception class

@Transactional //Spring transactional
void saveFile(ExcelFile file) {
    //Each sheet have different kind of entities and it is an ordered insert and first insert is needed before the second set of inserts
    for(each sheet in excel file) {
        List<Entity> entityList = convertIntoEntities(sheet);
        ValidationResult vr = validateEntities(entityList);
        saveEntities(entityList);
    }

    ValidationResult validateEntities(List<Entity> entityList) {
    validator.validate(entityList) // The new validation we need to do before 
}

void saveEntities(List<Entity> entityList) {
    dao.saveEntities(entityList);
}

此处实体列表是在读取 excel 文件后形成的,我们正在添加验证 excel 文件的逻辑。我们不能只验证 excel 本身,我们需要在验证之前读取现有的数据库条目。

现在验证器验证 excel 我们需要查看数据库中现有实体(其他 table 的实体)(这不是外部约束,有一些业务逻辑)和它为每个无效实体创建一个 validationErrorMessages 列表。

验证的结构 class 是

ValidationResult {
 boolean isValid;
List<String> errorMessage;
}

我想到了两个解决方案

  1. 更改保存的签名并发送ValidationResult(或将其包装到另一个class)。在那种情况下,我们需要自己管理回滚,因为当我们不抛出异常时,@Transactional 不会回滚工作

  2. 抛出具有 validationResult 的 InvalidInputFileException。 (我们要存储 ValidationResult 的原因是我们需要通知用户验证失败)。

我赞成这种方法,因为对于不一致的数据抛出异常是正确的,其次@Transactional 可以正常工作,我们不需要管理事务。 但是我之前在代码中没有看到Exception class中的成员变量,这样做可以吗?

现在我想到的一种方法是在 ValidationFailure 的情况下抛出

class InvalidInputFileException extends RuntimeException {
ValidationResult vr;

}

是的,很好。一个例外是 class,它可以像任何其他 class 一样拥有成员变量和方法。顺便说一下,这种异常的一个非常接近的例子就是标准 Bean Validation 框架抛出的标准 ConstraintValidationException,它包含一组约束违规。

不过,通常使异常不可变:它的状态在创建时设置,之后永远不会改变。